| 1 | /*------------------------------------------------------------------------- |
| 2 | * |
| 3 | * syscache.h |
| 4 | * System catalog cache definitions. |
| 5 | * |
| 6 | * See also lsyscache.h, which provides convenience routines for |
| 7 | * common cache-lookup operations. |
| 8 | * |
| 9 | * Portions Copyright (c) 1996-2019, PostgreSQL Global Development Group |
| 10 | * Portions Copyright (c) 1994, Regents of the University of California |
| 11 | * |
| 12 | * src/include/utils/syscache.h |
| 13 | * |
| 14 | *------------------------------------------------------------------------- |
| 15 | */ |
| 16 | #ifndef SYSCACHE_H |
| 17 | #define SYSCACHE_H |
| 18 | |
| 19 | #include "access/attnum.h" |
| 20 | #include "access/htup.h" |
| 21 | /* we intentionally do not include utils/catcache.h here */ |
| 22 | |
| 23 | /* |
| 24 | * SysCache identifiers. |
| 25 | * |
| 26 | * The order of these identifiers must match the order |
| 27 | * of the entries in the array cacheinfo[] in syscache.c. |
| 28 | * Keep them in alphabetical order (renumbering only costs a |
| 29 | * backend rebuild). |
| 30 | */ |
| 31 | |
| 32 | enum SysCacheIdentifier |
| 33 | { |
| 34 | AGGFNOID = 0, |
| 35 | AMNAME, |
| 36 | AMOID, |
| 37 | AMOPOPID, |
| 38 | AMOPSTRATEGY, |
| 39 | AMPROCNUM, |
| 40 | ATTNAME, |
| 41 | ATTNUM, |
| 42 | AUTHMEMMEMROLE, |
| 43 | AUTHMEMROLEMEM, |
| 44 | AUTHNAME, |
| 45 | AUTHOID, |
| 46 | CASTSOURCETARGET, |
| 47 | CLAAMNAMENSP, |
| 48 | CLAOID, |
| 49 | COLLNAMEENCNSP, |
| 50 | COLLOID, |
| 51 | CONDEFAULT, |
| 52 | CONNAMENSP, |
| 53 | CONSTROID, |
| 54 | CONVOID, |
| 55 | DATABASEOID, |
| 56 | DEFACLROLENSPOBJ, |
| 57 | ENUMOID, |
| 58 | ENUMTYPOIDNAME, |
| 59 | EVENTTRIGGERNAME, |
| 60 | EVENTTRIGGEROID, |
| 61 | FOREIGNDATAWRAPPERNAME, |
| 62 | FOREIGNDATAWRAPPEROID, |
| 63 | FOREIGNSERVERNAME, |
| 64 | FOREIGNSERVEROID, |
| 65 | FOREIGNTABLEREL, |
| 66 | INDEXRELID, |
| 67 | LANGNAME, |
| 68 | LANGOID, |
| 69 | NAMESPACENAME, |
| 70 | NAMESPACEOID, |
| 71 | OPERNAMENSP, |
| 72 | OPEROID, |
| 73 | OPFAMILYAMNAMENSP, |
| 74 | OPFAMILYOID, |
| 75 | PARTRELID, |
| 76 | PROCNAMEARGSNSP, |
| 77 | PROCOID, |
| 78 | PUBLICATIONNAME, |
| 79 | PUBLICATIONOID, |
| 80 | PUBLICATIONREL, |
| 81 | PUBLICATIONRELMAP, |
| 82 | RANGETYPE, |
| 83 | RELNAMENSP, |
| 84 | RELOID, |
| 85 | REPLORIGIDENT, |
| 86 | REPLORIGNAME, |
| 87 | RULERELNAME, |
| 88 | SEQRELID, |
| 89 | STATEXTDATASTXOID, |
| 90 | STATEXTNAMENSP, |
| 91 | STATEXTOID, |
| 92 | STATRELATTINH, |
| 93 | SUBSCRIPTIONNAME, |
| 94 | SUBSCRIPTIONOID, |
| 95 | SUBSCRIPTIONRELMAP, |
| 96 | TABLESPACEOID, |
| 97 | TRFOID, |
| 98 | TRFTYPELANG, |
| 99 | TSCONFIGMAP, |
| 100 | TSCONFIGNAMENSP, |
| 101 | TSCONFIGOID, |
| 102 | TSDICTNAMENSP, |
| 103 | TSDICTOID, |
| 104 | TSPARSERNAMENSP, |
| 105 | TSPARSEROID, |
| 106 | TSTEMPLATENAMENSP, |
| 107 | TSTEMPLATEOID, |
| 108 | TYPENAMENSP, |
| 109 | TYPEOID, |
| 110 | USERMAPPINGOID, |
| 111 | USERMAPPINGUSERSERVER |
| 112 | |
| 113 | #define SysCacheSize (USERMAPPINGUSERSERVER + 1) |
| 114 | }; |
| 115 | |
| 116 | extern void InitCatalogCache(void); |
| 117 | extern void InitCatalogCachePhase2(void); |
| 118 | |
| 119 | extern HeapTuple SearchSysCache(int cacheId, |
| 120 | Datum key1, Datum key2, Datum key3, Datum key4); |
| 121 | |
| 122 | /* |
| 123 | * The use of argument specific numbers is encouraged. They're faster, and |
| 124 | * insulates the caller from changes in the maximum number of keys. |
| 125 | */ |
| 126 | extern HeapTuple SearchSysCache1(int cacheId, |
| 127 | Datum key1); |
| 128 | extern HeapTuple SearchSysCache2(int cacheId, |
| 129 | Datum key1, Datum key2); |
| 130 | extern HeapTuple SearchSysCache3(int cacheId, |
| 131 | Datum key1, Datum key2, Datum key3); |
| 132 | extern HeapTuple SearchSysCache4(int cacheId, |
| 133 | Datum key1, Datum key2, Datum key3, Datum key4); |
| 134 | |
| 135 | extern void ReleaseSysCache(HeapTuple tuple); |
| 136 | |
| 137 | /* convenience routines */ |
| 138 | extern HeapTuple SearchSysCacheCopy(int cacheId, |
| 139 | Datum key1, Datum key2, Datum key3, Datum key4); |
| 140 | extern bool SearchSysCacheExists(int cacheId, |
| 141 | Datum key1, Datum key2, Datum key3, Datum key4); |
| 142 | extern Oid GetSysCacheOid(int cacheId, AttrNumber oidcol, |
| 143 | Datum key1, Datum key2, Datum key3, Datum key4); |
| 144 | |
| 145 | extern HeapTuple SearchSysCacheAttName(Oid relid, const char *attname); |
| 146 | extern HeapTuple SearchSysCacheCopyAttName(Oid relid, const char *attname); |
| 147 | extern bool SearchSysCacheExistsAttName(Oid relid, const char *attname); |
| 148 | |
| 149 | extern HeapTuple SearchSysCacheAttNum(Oid relid, int16 attnum); |
| 150 | extern HeapTuple SearchSysCacheCopyAttNum(Oid relid, int16 attnum); |
| 151 | |
| 152 | extern Datum SysCacheGetAttr(int cacheId, HeapTuple tup, |
| 153 | AttrNumber attributeNumber, bool *isNull); |
| 154 | |
| 155 | extern uint32 GetSysCacheHashValue(int cacheId, |
| 156 | Datum key1, Datum key2, Datum key3, Datum key4); |
| 157 | |
| 158 | /* list-search interface. Users of this must import catcache.h too */ |
| 159 | struct catclist; |
| 160 | extern struct catclist *SearchSysCacheList(int cacheId, int nkeys, |
| 161 | Datum key1, Datum key2, Datum key3); |
| 162 | |
| 163 | extern void SysCacheInvalidate(int cacheId, uint32 hashValue); |
| 164 | |
| 165 | extern bool RelationInvalidatesSnapshotsOnly(Oid relid); |
| 166 | extern bool RelationHasSysCache(Oid relid); |
| 167 | extern bool RelationSupportsSysCache(Oid relid); |
| 168 | |
| 169 | /* |
| 170 | * The use of the macros below rather than direct calls to the corresponding |
| 171 | * functions is encouraged, as it insulates the caller from changes in the |
| 172 | * maximum number of keys. |
| 173 | */ |
| 174 | #define SearchSysCacheCopy1(cacheId, key1) \ |
| 175 | SearchSysCacheCopy(cacheId, key1, 0, 0, 0) |
| 176 | #define SearchSysCacheCopy2(cacheId, key1, key2) \ |
| 177 | SearchSysCacheCopy(cacheId, key1, key2, 0, 0) |
| 178 | #define SearchSysCacheCopy3(cacheId, key1, key2, key3) \ |
| 179 | SearchSysCacheCopy(cacheId, key1, key2, key3, 0) |
| 180 | #define SearchSysCacheCopy4(cacheId, key1, key2, key3, key4) \ |
| 181 | SearchSysCacheCopy(cacheId, key1, key2, key3, key4) |
| 182 | |
| 183 | #define SearchSysCacheExists1(cacheId, key1) \ |
| 184 | SearchSysCacheExists(cacheId, key1, 0, 0, 0) |
| 185 | #define SearchSysCacheExists2(cacheId, key1, key2) \ |
| 186 | SearchSysCacheExists(cacheId, key1, key2, 0, 0) |
| 187 | #define SearchSysCacheExists3(cacheId, key1, key2, key3) \ |
| 188 | SearchSysCacheExists(cacheId, key1, key2, key3, 0) |
| 189 | #define SearchSysCacheExists4(cacheId, key1, key2, key3, key4) \ |
| 190 | SearchSysCacheExists(cacheId, key1, key2, key3, key4) |
| 191 | |
| 192 | #define GetSysCacheOid1(cacheId, oidcol, key1) \ |
| 193 | GetSysCacheOid(cacheId, oidcol, key1, 0, 0, 0) |
| 194 | #define GetSysCacheOid2(cacheId, oidcol, key1, key2) \ |
| 195 | GetSysCacheOid(cacheId, oidcol, key1, key2, 0, 0) |
| 196 | #define GetSysCacheOid3(cacheId, oidcol, key1, key2, key3) \ |
| 197 | GetSysCacheOid(cacheId, oidcol, key1, key2, key3, 0) |
| 198 | #define GetSysCacheOid4(cacheId, oidcol, key1, key2, key3, key4) \ |
| 199 | GetSysCacheOid(cacheId, oidcol, key1, key2, key3, key4) |
| 200 | |
| 201 | #define GetSysCacheHashValue1(cacheId, key1) \ |
| 202 | GetSysCacheHashValue(cacheId, key1, 0, 0, 0) |
| 203 | #define GetSysCacheHashValue2(cacheId, key1, key2) \ |
| 204 | GetSysCacheHashValue(cacheId, key1, key2, 0, 0) |
| 205 | #define GetSysCacheHashValue3(cacheId, key1, key2, key3) \ |
| 206 | GetSysCacheHashValue(cacheId, key1, key2, key3, 0) |
| 207 | #define GetSysCacheHashValue4(cacheId, key1, key2, key3, key4) \ |
| 208 | GetSysCacheHashValue(cacheId, key1, key2, key3, key4) |
| 209 | |
| 210 | #define SearchSysCacheList1(cacheId, key1) \ |
| 211 | SearchSysCacheList(cacheId, 1, key1, 0, 0) |
| 212 | #define SearchSysCacheList2(cacheId, key1, key2) \ |
| 213 | SearchSysCacheList(cacheId, 2, key1, key2, 0) |
| 214 | #define SearchSysCacheList3(cacheId, key1, key2, key3) \ |
| 215 | SearchSysCacheList(cacheId, 3, key1, key2, key3) |
| 216 | |
| 217 | #define ReleaseSysCacheList(x) ReleaseCatCacheList(x) |
| 218 | |
| 219 | #endif /* SYSCACHE_H */ |
| 220 | |