Age Owner Branch data TLA Line data Source code
1 : : /*-------------------------------------------------------------------------
2 : : *
3 : : * index.h
4 : : * prototypes for catalog/index.c.
5 : : *
6 : : *
7 : : * Portions Copyright (c) 1996-2024, PostgreSQL Global Development Group
8 : : * Portions Copyright (c) 1994, Regents of the University of California
9 : : *
10 : : * src/include/catalog/index.h
11 : : *
12 : : *-------------------------------------------------------------------------
13 : : */
14 : : #ifndef INDEX_H
15 : : #define INDEX_H
16 : :
17 : : #include "catalog/objectaddress.h"
18 : : #include "nodes/execnodes.h"
19 : :
20 : :
21 : : #define DEFAULT_INDEX_TYPE "btree"
22 : :
23 : : /* Action code for index_set_state_flags */
24 : : typedef enum
25 : : {
26 : : INDEX_CREATE_SET_READY,
27 : : INDEX_CREATE_SET_VALID,
28 : : INDEX_DROP_CLEAR_VALID,
29 : : INDEX_DROP_SET_DEAD,
30 : : } IndexStateFlagsAction;
31 : :
32 : : /* options for REINDEX */
33 : : typedef struct ReindexParams
34 : : {
35 : : bits32 options; /* bitmask of REINDEXOPT_* */
36 : : Oid tablespaceOid; /* New tablespace to move indexes to.
37 : : * InvalidOid to do nothing. */
38 : : } ReindexParams;
39 : :
40 : : /* flag bits for ReindexParams->flags */
41 : : #define REINDEXOPT_VERBOSE 0x01 /* print progress info */
42 : : #define REINDEXOPT_REPORT_PROGRESS 0x02 /* report pgstat progress */
43 : : #define REINDEXOPT_MISSING_OK 0x04 /* skip missing relations */
44 : : #define REINDEXOPT_CONCURRENTLY 0x08 /* concurrent mode */
45 : :
46 : : /* state info for validate_index bulkdelete callback */
47 : : typedef struct ValidateIndexState
48 : : {
49 : : Tuplesortstate *tuplesort; /* for sorting the index TIDs */
50 : : /* statistics (for debug purposes only): */
51 : : double htups,
52 : : itups,
53 : : tups_inserted;
54 : : } ValidateIndexState;
55 : :
56 : : extern void index_check_primary_key(Relation heapRel,
57 : : const IndexInfo *indexInfo,
58 : : bool is_alter_table,
59 : : const IndexStmt *stmt);
60 : :
61 : : #define INDEX_CREATE_IS_PRIMARY (1 << 0)
62 : : #define INDEX_CREATE_ADD_CONSTRAINT (1 << 1)
63 : : #define INDEX_CREATE_SKIP_BUILD (1 << 2)
64 : : #define INDEX_CREATE_CONCURRENT (1 << 3)
65 : : #define INDEX_CREATE_IF_NOT_EXISTS (1 << 4)
66 : : #define INDEX_CREATE_PARTITIONED (1 << 5)
67 : : #define INDEX_CREATE_INVALID (1 << 6)
68 : :
69 : : extern Oid index_create(Relation heapRelation,
70 : : const char *indexRelationName,
71 : : Oid indexRelationId,
72 : : Oid parentIndexRelid,
73 : : Oid parentConstraintId,
74 : : RelFileNumber relFileNumber,
75 : : IndexInfo *indexInfo,
76 : : const List *indexColNames,
77 : : Oid accessMethodId,
78 : : Oid tableSpaceId,
79 : : const Oid *collationIds,
80 : : const Oid *opclassIds,
81 : : const Datum *opclassOptions,
82 : : const int16 *coloptions,
83 : : const NullableDatum *stattargets,
84 : : Datum reloptions,
85 : : bits16 flags,
86 : : bits16 constr_flags,
87 : : bool allow_system_table_mods,
88 : : bool is_internal,
89 : : Oid *constraintId);
90 : :
91 : : #define INDEX_CONSTR_CREATE_MARK_AS_PRIMARY (1 << 0)
92 : : #define INDEX_CONSTR_CREATE_DEFERRABLE (1 << 1)
93 : : #define INDEX_CONSTR_CREATE_INIT_DEFERRED (1 << 2)
94 : : #define INDEX_CONSTR_CREATE_UPDATE_INDEX (1 << 3)
95 : : #define INDEX_CONSTR_CREATE_REMOVE_OLD_DEPS (1 << 4)
96 : : #define INDEX_CONSTR_CREATE_WITHOUT_OVERLAPS (1 << 5)
97 : :
98 : : extern Oid index_concurrently_create_copy(Relation heapRelation,
99 : : Oid oldIndexId,
100 : : Oid tablespaceOid,
101 : : const char *newName);
102 : :
103 : : extern void index_concurrently_build(Oid heapRelationId,
104 : : Oid indexRelationId);
105 : :
106 : : extern void index_concurrently_swap(Oid newIndexId,
107 : : Oid oldIndexId,
108 : : const char *oldName);
109 : :
110 : : extern void index_concurrently_set_dead(Oid heapId,
111 : : Oid indexId);
112 : :
113 : : extern ObjectAddress index_constraint_create(Relation heapRelation,
114 : : Oid indexRelationId,
115 : : Oid parentConstraintId,
116 : : const IndexInfo *indexInfo,
117 : : const char *constraintName,
118 : : char constraintType,
119 : : bits16 constr_flags,
120 : : bool allow_system_table_mods,
121 : : bool is_internal);
122 : :
123 : : extern void index_drop(Oid indexId, bool concurrent, bool concurrent_lock_mode);
124 : :
125 : : extern IndexInfo *BuildIndexInfo(Relation index);
126 : :
127 : : extern IndexInfo *BuildDummyIndexInfo(Relation index);
128 : :
129 : : extern bool CompareIndexInfo(const IndexInfo *info1, const IndexInfo *info2,
130 : : const Oid *collations1, const Oid *collations2,
131 : : const Oid *opfamilies1, const Oid *opfamilies2,
132 : : const AttrMap *attmap);
133 : :
134 : : extern void BuildSpeculativeIndexInfo(Relation index, IndexInfo *ii);
135 : :
136 : : extern void FormIndexDatum(IndexInfo *indexInfo,
137 : : TupleTableSlot *slot,
138 : : EState *estate,
139 : : Datum *values,
140 : : bool *isnull);
141 : :
142 : : extern void index_build(Relation heapRelation,
143 : : Relation indexRelation,
144 : : IndexInfo *indexInfo,
145 : : bool isreindex,
146 : : bool parallel);
147 : :
148 : : extern void validate_index(Oid heapId, Oid indexId, Snapshot snapshot);
149 : :
150 : : extern void index_set_state_flags(Oid indexId, IndexStateFlagsAction action);
151 : :
152 : : extern Oid IndexGetRelation(Oid indexId, bool missing_ok);
153 : :
154 : : extern void reindex_index(const ReindexStmt *stmt, Oid indexId,
155 : : bool skip_constraint_checks, char persistence,
156 : : const ReindexParams *params);
157 : :
158 : : /* Flag bits for reindex_relation(): */
159 : : #define REINDEX_REL_PROCESS_TOAST 0x01
160 : : #define REINDEX_REL_SUPPRESS_INDEX_USE 0x02
161 : : #define REINDEX_REL_CHECK_CONSTRAINTS 0x04
162 : : #define REINDEX_REL_FORCE_INDEXES_UNLOGGED 0x08
163 : : #define REINDEX_REL_FORCE_INDEXES_PERMANENT 0x10
164 : :
165 : : extern bool reindex_relation(const ReindexStmt *stmt, Oid relid, int flags,
166 : : const ReindexParams *params);
167 : :
168 : : extern bool ReindexIsProcessingHeap(Oid heapOid);
169 : : extern bool ReindexIsProcessingIndex(Oid indexOid);
170 : :
171 : : extern void ResetReindexState(int nestLevel);
172 : : extern Size EstimateReindexStateSpace(void);
173 : : extern void SerializeReindexState(Size maxsize, char *start_address);
174 : : extern void RestoreReindexState(const void *reindexstate);
175 : :
176 : : extern void IndexSetParentIndex(Relation partitionIdx, Oid parentOid);
177 : :
178 : :
179 : : /*
180 : : * itemptr_encode - Encode ItemPointer as int64/int8
181 : : *
182 : : * This representation must produce values encoded as int64 that sort in the
183 : : * same order as their corresponding original TID values would (using the
184 : : * default int8 opclass to produce a result equivalent to the default TID
185 : : * opclass).
186 : : *
187 : : * As noted in validate_index(), this can be significantly faster.
188 : : */
189 : : static inline int64
1845 andres@anarazel.de 190 :CBC 17297 : itemptr_encode(ItemPointer itemptr)
191 : : {
192 : 17297 : BlockNumber block = ItemPointerGetBlockNumber(itemptr);
193 : 17297 : OffsetNumber offset = ItemPointerGetOffsetNumber(itemptr);
194 : : int64 encoded;
195 : :
196 : : /*
197 : : * Use the 16 least significant bits for the offset. 32 adjacent bits are
198 : : * used for the block number. Since remaining bits are unused, there
199 : : * cannot be negative encoded values (We assume a two's complement
200 : : * representation).
201 : : */
202 : 17297 : encoded = ((uint64) block << 16) | (uint16) offset;
203 : :
204 : 17297 : return encoded;
205 : : }
206 : :
207 : : /*
208 : : * itemptr_decode - Decode int64/int8 representation back to ItemPointer
209 : : */
210 : : static inline void
211 : 17281 : itemptr_decode(ItemPointer itemptr, int64 encoded)
212 : : {
213 : 17281 : BlockNumber block = (BlockNumber) (encoded >> 16);
214 : 17281 : OffsetNumber offset = (OffsetNumber) (encoded & 0xFFFF);
215 : :
216 : 17281 : ItemPointerSet(itemptr, block, offset);
217 : 17281 : }
218 : :
219 : : #endif /* INDEX_H */
|