1 /*-------------------------------------------------------------------------
4 * Relation descriptor cache definitions.
7 * Portions Copyright (c) 1996-2014, PostgreSQL Global Development Group
8 * Portions Copyright (c) 1994, Regents of the University of California
10 * src/include/utils/relcache.h
12 *-------------------------------------------------------------------------
17 #include "access/tupdesc.h"
18 #include "nodes/bitmapset.h"
21 typedef struct RelationData *Relation;
24 * RelationPtr is used in the executor to support index scans
25 * where we have to keep track of several index relations in an
29 typedef Relation *RelationPtr;
32 * Routines to open (lookup) and close a relcache entry
34 extern Relation RelationIdGetRelation(Oid relationId);
35 extern void RelationClose(Relation relation);
38 * Routines to compute/retrieve additional cached information
40 extern List *RelationGetIndexList(Relation relation);
41 extern Oid RelationGetOidIndex(Relation relation);
42 extern List *RelationGetIndexExpressions(Relation relation);
43 extern List *RelationGetIndexPredicate(Relation relation);
45 typedef enum IndexAttrBitmapKind
47 INDEX_ATTR_BITMAP_ALL,
48 INDEX_ATTR_BITMAP_KEY,
49 INDEX_ATTR_BITMAP_IDENTITY_KEY
50 } IndexAttrBitmapKind;
52 extern Bitmapset *RelationGetIndexAttrBitmap(Relation relation,
53 IndexAttrBitmapKind keyAttrs);
55 extern void RelationGetExclusionInfo(Relation indexRelation,
60 extern void RelationSetIndexList(Relation relation,
61 List *indexIds, Oid oidIndex);
63 extern void RelationInitIndexAccessInfo(Relation relation);
66 * Routines to support ereport() reports of relation-related errors
68 extern int errtable(Relation rel);
69 extern int errtablecol(Relation rel, int attnum);
70 extern int errtablecolname(Relation rel, const char *colname);
71 extern int errtableconstraint(Relation rel, const char *conname);
74 * Routines for backend startup
76 extern void RelationCacheInitialize(void);
77 extern void RelationCacheInitializePhase2(void);
78 extern void RelationCacheInitializePhase3(void);
81 * Routine to create a relcache entry for an about-to-be-created relation
83 extern Relation RelationBuildLocalRelation(const char *relname,
95 * Routine to manage assignment of new relfilenode to a relation
97 extern void RelationSetNewRelfilenode(Relation relation,
98 TransactionId freezeXid, MultiXactId minmulti);
101 * Routines for flushing/rebuilding relcache entries in various scenarios
103 extern void RelationForgetRelation(Oid rid);
105 extern void RelationCacheInvalidateEntry(Oid relationId);
107 extern void RelationCacheInvalidate(void);
109 extern void RelationCloseSmgrByOid(Oid relationId);
111 extern void AtEOXact_RelationCache(bool isCommit);
112 extern void AtEOSubXact_RelationCache(bool isCommit, SubTransactionId mySubid,
113 SubTransactionId parentSubid);
116 * Routines to help manage rebuilding of relcache init files
118 extern bool RelationIdIsInInitFile(Oid relationId);
119 extern void RelationCacheInitFilePreInvalidate(void);
120 extern void RelationCacheInitFilePostInvalidate(void);
121 extern void RelationCacheInitFileRemove(void);
123 /* should be used only by relcache.c and catcache.c */
124 extern bool criticalRelcachesBuilt;
126 /* should be used only by relcache.c and postinit.c */
127 extern bool criticalSharedRelcachesBuilt;
129 #endif /* RELCACHE_H */