PostgreSQL Source Code git master
Loading...
Searching...
No Matches
lsyscache.h
Go to the documentation of this file.
1/*-------------------------------------------------------------------------
2 *
3 * lsyscache.h
4 * Convenience routines for common queries in the system catalog cache.
5 *
6 * Portions Copyright (c) 1996-2026, PostgreSQL Global Development Group
7 * Portions Copyright (c) 1994, Regents of the University of California
8 *
9 * src/include/utils/lsyscache.h
10 *
11 *-------------------------------------------------------------------------
12 */
13#ifndef LSYSCACHE_H
14#define LSYSCACHE_H
15
16#include "access/attnum.h"
17#include "access/cmptype.h"
18#include "access/htup.h"
19#include "nodes/pg_list.h"
20
21/* avoid including subscripting.h here */
23
24/* Result list element for get_op_index_interpretation */
26{
27 Oid opfamily_id; /* opfamily containing operator */
28 CompareType cmptype; /* its generic comparison type */
29 Oid oplefttype; /* declared left input datatype */
30 Oid oprighttype; /* declared right input datatype */
32
33/* I/O function selector for get_type_io_data */
41
42/* Flag bits for get_attstatsslot */
43#define ATTSTATSSLOT_VALUES 0x01
44#define ATTSTATSSLOT_NUMBERS 0x02
45
46/* Result struct for get_attstatsslot */
47typedef struct AttStatsSlot
48{
49 /* Always filled: */
50 Oid staop; /* Actual staop for the found slot */
51 Oid stacoll; /* Actual collation for the found slot */
52 /* Filled if ATTSTATSSLOT_VALUES is specified: */
53 Oid valuetype; /* Actual datatype of the values */
54 Datum *values; /* slot's "values" array, or NULL if none */
55 int nvalues; /* length of values[], or 0 */
56 /* Filled if ATTSTATSSLOT_NUMBERS is specified: */
57 float4 *numbers; /* slot's "numbers" array, or NULL if none */
58 int nnumbers; /* length of numbers[], or 0 */
59
60 /* Remaining fields are private to get_attstatsslot/free_attstatsslot */
61 void *values_arr; /* palloc'd values array, if any */
62 void *numbers_arr; /* palloc'd numbers array, if any */
64
65/* Hook for plugins to get control in get_attavgwidth() */
68
69extern bool op_in_opfamily(Oid opno, Oid opfamily);
70extern int get_op_opfamily_strategy(Oid opno, Oid opfamily);
71extern Oid get_op_opfamily_sortfamily(Oid opno, Oid opfamily);
72extern void get_op_opfamily_properties(Oid opno, Oid opfamily, bool ordering_op,
73 int *strategy,
74 Oid *lefttype,
75 Oid *righttype);
76extern Oid get_opfamily_member(Oid opfamily, Oid lefttype, Oid righttype,
77 int16 strategy);
78extern Oid get_opfamily_member_for_cmptype(Oid opfamily, Oid lefttype, Oid righttype,
79 CompareType cmptype);
80extern bool get_ordering_op_properties(Oid opno,
81 Oid *opfamily, Oid *opcintype, CompareType *cmptype);
82extern Oid get_equality_op_for_ordering_op(Oid opno, bool *reverse);
85extern bool get_compatible_hash_operators(Oid opno,
87extern bool get_op_hash_functions(Oid opno,
89extern bool get_op_hash_functions_ext(Oid opno, Oid inputtype,
95extern bool op_is_safe_index_member(Oid opno);
96extern Oid get_opfamily_proc(Oid opfamily, Oid lefttype, Oid righttype,
98extern char *get_attname(Oid relid, AttrNumber attnum, bool missing_ok);
99extern AttrNumber get_attnum(Oid relid, const char *attname);
100extern char get_attgenerated(Oid relid, AttrNumber attnum);
101extern Oid get_atttype(Oid relid, AttrNumber attnum);
102extern void get_atttypetypmodcoll(Oid relid, AttrNumber attnum,
103 Oid *typid, int32 *typmod, Oid *collid);
104extern Datum get_attoptions(Oid relid, int16 attnum);
105extern Oid get_cast_oid(Oid sourcetypeid, Oid targettypeid, bool missing_ok);
106extern char *get_collation_name(Oid colloid);
107extern bool get_collation_isdeterministic(Oid colloid);
108extern char *get_constraint_name(Oid conoid);
109extern Oid get_constraint_index(Oid conoid);
110extern char get_constraint_type(Oid conoid);
111extern char *get_database_name(Oid dbid);
112extern char *get_language_name(Oid langoid, bool missing_ok);
113extern Oid get_opclass_family(Oid opclass);
114extern Oid get_opclass_input_type(Oid opclass);
115extern bool get_opclass_opfamily_and_input_type(Oid opclass,
116 Oid *opfamily, Oid *opcintype);
117extern Oid get_opclass_method(Oid opclass);
119extern char *get_opfamily_name(Oid opfid, bool missing_ok);
120extern RegProcedure get_opcode(Oid opno);
121extern char *get_opname(Oid opno);
122extern Oid get_op_rettype(Oid opno);
123extern void op_input_types(Oid opno, Oid *lefttype, Oid *righttype);
124extern bool op_mergejoinable(Oid opno, Oid inputtype);
125extern bool op_hashjoinable(Oid opno, Oid inputtype);
126extern bool op_strict(Oid opno);
127extern char op_volatile(Oid opno);
128extern Oid get_commutator(Oid opno);
129extern Oid get_negator(Oid opno);
130extern RegProcedure get_oprrest(Oid opno);
131extern RegProcedure get_oprjoin(Oid opno);
132extern char *get_func_name(Oid funcid);
133extern Oid get_func_namespace(Oid funcid);
134extern Oid get_func_rettype(Oid funcid);
135extern int get_func_nargs(Oid funcid);
136extern Oid get_func_signature(Oid funcid, Oid **argtypes, int *nargs);
137extern Oid get_func_variadictype(Oid funcid);
138extern bool get_func_retset(Oid funcid);
139extern bool func_strict(Oid funcid);
140extern char func_volatile(Oid funcid);
141extern char func_parallel(Oid funcid);
142extern char get_func_prokind(Oid funcid);
143extern bool get_func_leakproof(Oid funcid);
144extern RegProcedure get_func_support(Oid funcid);
145extern Oid get_relname_relid(const char *relname, Oid relnamespace);
146extern char *get_rel_name(Oid relid);
147extern Oid get_rel_namespace(Oid relid);
148extern Oid get_rel_type_id(Oid relid);
149extern char get_rel_relkind(Oid relid);
150extern bool get_rel_relispartition(Oid relid);
151extern Oid get_rel_tablespace(Oid relid);
152extern char get_rel_persistence(Oid relid);
153extern Oid get_rel_relam(Oid relid);
154extern Oid get_transform_fromsql(Oid typid, Oid langid, List *trftypes);
155extern Oid get_transform_tosql(Oid typid, Oid langid, List *trftypes);
156extern bool get_typisdefined(Oid typid);
157extern int16 get_typlen(Oid typid);
158extern bool get_typbyval(Oid typid);
159extern void get_typlenbyval(Oid typid, int16 *typlen, bool *typbyval);
160extern void get_typlenbyvalalign(Oid typid, int16 *typlen, bool *typbyval,
161 char *typalign);
163extern void get_type_io_data(Oid typid,
165 int16 *typlen,
166 bool *typbyval,
167 char *typalign,
168 char *typdelim,
169 Oid *typioparam,
170 Oid *func);
171extern char get_typstorage(Oid typid);
172extern Node *get_typdefault(Oid typid);
173extern char get_typtype(Oid typid);
174extern bool type_is_rowtype(Oid typid);
175extern bool type_is_enum(Oid typid);
176extern bool type_is_range(Oid typid);
177extern bool type_is_multirange(Oid typid);
178extern void get_type_category_preferred(Oid typid,
179 char *typcategory,
180 bool *typispreferred);
181extern Oid get_typ_typrelid(Oid typid);
182extern Oid get_element_type(Oid typid);
183extern Oid get_array_type(Oid typid);
184extern Oid get_promoted_array_type(Oid typid);
185extern Oid get_base_element_type(Oid typid);
187extern void getTypeOutputInfo(Oid type, Oid *typOutput, bool *typIsVarlena);
190extern Oid get_typmodin(Oid typid);
191extern Oid get_typcollation(Oid typid);
192extern bool type_is_collatable(Oid typid);
195 Oid *typelemp);
196extern Oid getBaseType(Oid typid);
197extern Oid getBaseTypeAndTypmod(Oid typid, int32 *typmod);
198extern int32 get_typavgwidth(Oid typid, int32 typmod);
201 int reqkind, Oid reqop, int flags);
203extern char *get_namespace_name(Oid nspid);
205extern char *get_qualified_objname(Oid nspid, char *objname);
211extern Oid get_index_column_opclass(Oid index_oid, int attno);
213extern bool get_index_isvalid(Oid index_oid);
215extern Oid get_publication_oid(const char *pubname, bool missing_ok);
216extern char *get_publication_name(Oid pubid, bool missing_ok);
217extern Oid get_subscription_oid(const char *subname, bool missing_ok);
218extern char *get_subscription_name(Oid subid, bool missing_ok);
219
222
223#define type_is_array(typid) (get_element_type(typid) != InvalidOid)
224/* type_is_array_domain accepts both plain arrays and domains over arrays */
225#define type_is_array_domain(typid) (get_base_element_type(typid) != InvalidOid)
226
227#define TypeIsToastable(typid) (get_typstorage(typid) != TYPSTORAGE_PLAIN)
228
229#endif /* LSYSCACHE_H */
int16 AttrNumber
Definition attnum.h:21
#define PGDLLIMPORT
Definition c.h:1433
int16_t int16
Definition c.h:619
regproc RegProcedure
Definition c.h:734
int32_t int32
Definition c.h:620
float float4
Definition c.h:713
CompareType
Definition cmptype.h:32
int nspid
Oid collid
Oid get_range_subtype(Oid rangeOid)
Definition lsyscache.c:3735
char * get_rel_name(Oid relid)
Definition lsyscache.c:2234
void get_op_opfamily_properties(Oid opno, Oid opfamily, bool ordering_op, int *strategy, Oid *lefttype, Oid *righttype)
Definition lsyscache.c:140
Oid get_func_variadictype(Oid funcid)
Definition lsyscache.c:2029
Oid get_opclass_method(Oid opclass)
Definition lsyscache.c:1504
bool get_compatible_hash_operators(Oid opno, Oid *lhs_opno, Oid *rhs_opno)
Definition lsyscache.c:483
bool get_rel_relispartition(Oid relid)
Definition lsyscache.c:2333
char * get_propgraph_property_name(Oid propoid)
Definition lsyscache.c:4090
Oid get_op_opfamily_sortfamily(Oid opno, Oid opfamily)
Definition lsyscache.c:112
bool collations_agree_on_equality(Oid coll1, Oid coll2)
Definition lsyscache.c:947
char get_rel_persistence(Oid relid)
Definition lsyscache.c:2384
char get_func_prokind(Oid funcid)
Definition lsyscache.c:2124
bool get_index_isvalid(Oid index_oid)
Definition lsyscache.c:3931
Oid get_cast_oid(Oid sourcetypeid, Oid targettypeid, bool missing_ok)
Definition lsyscache.c:1225
void getTypeBinaryOutputInfo(Oid type, Oid *typSend, bool *typIsVarlena)
Definition lsyscache.c:3281
const SubscriptRoutines * getSubscriptingRoutines(Oid typid, Oid *typelemp)
Definition lsyscache.c:3438
AttrNumber get_attnum(Oid relid, const char *attname)
Definition lsyscache.c:1076
RegProcedure get_oprrest(Oid opno)
Definition lsyscache.c:1863
void free_attstatsslot(AttStatsSlot *sslot)
Definition lsyscache.c:3652
bool comparison_ops_are_compatible(Oid opno1, Oid opno2)
Definition lsyscache.c:886
Oid get_constraint_index(Oid conoid)
Definition lsyscache.c:1331
bool get_func_retset(Oid funcid)
Definition lsyscache.c:2048
bool get_ordering_op_properties(Oid opno, Oid *opfamily, Oid *opcintype, CompareType *cmptype)
Definition lsyscache.c:261
Oid get_element_type(Oid typid)
Definition lsyscache.c:3067
Oid get_opclass_input_type(Oid opclass)
Definition lsyscache.c:1456
bool type_is_rowtype(Oid typid)
Definition lsyscache.c:2963
bool type_is_range(Oid typid)
Definition lsyscache.c:2996
char func_parallel(Oid funcid)
Definition lsyscache.c:2105
Oid get_opclass_family(Oid opclass)
Definition lsyscache.c:1434
char get_attgenerated(Oid relid, AttrNumber attnum)
Definition lsyscache.c:1106
bool type_is_enum(Oid typid)
Definition lsyscache.c:2986
Oid get_multirange_range(Oid multirangeOid)
Definition lsyscache.c:3836
Oid get_typmodin(Oid typid)
Definition lsyscache.c:3314
Oid get_opfamily_member_for_cmptype(Oid opfamily, Oid lefttype, Oid righttype, CompareType cmptype)
Definition lsyscache.c:199
char get_typstorage(Oid typid)
Definition lsyscache.c:2727
bool get_opclass_opfamily_and_input_type(Oid opclass, Oid *opfamily, Oid *opcintype)
Definition lsyscache.c:1479
RegProcedure get_func_support(Oid funcid)
Definition lsyscache.c:2164
char * get_database_name(Oid dbid)
Definition lsyscache.c:1384
PGDLLIMPORT get_attavgwidth_hook_type get_attavgwidth_hook
Definition lsyscache.c:57
void getTypeOutputInfo(Oid type, Oid *typOutput, bool *typIsVarlena)
Definition lsyscache.c:3215
bool get_typisdefined(Oid typid)
Definition lsyscache.c:2479
char * get_opname(Oid opno)
Definition lsyscache.c:1602
Datum get_attoptions(Oid relid, int16 attnum)
Definition lsyscache.c:1188
void get_typlenbyvalalign(Oid typid, int16 *typlen, bool *typbyval, char *typalign)
Definition lsyscache.c:2577
int32 get_attavgwidth(Oid relid, AttrNumber attnum)
Definition lsyscache.c:3466
bool get_index_isreplident(Oid index_oid)
Definition lsyscache.c:3908
Oid get_opfamily_proc(Oid opfamily, Oid lefttype, Oid righttype, int16 procnum)
Definition lsyscache.c:1014
RegProcedure get_oprjoin(Oid opno)
Definition lsyscache.c:1887
Oid get_equality_op_for_ordering_op(Oid opno, bool *reverse)
Definition lsyscache.c:326
bool op_strict(Oid opno)
Definition lsyscache.c:1783
bool op_hashjoinable(Oid opno, Oid inputtype)
Definition lsyscache.c:1731
char get_rel_relkind(Oid relid)
Definition lsyscache.c:2309
void get_typlenbyval(Oid typid, int16 *typlen, bool *typbyval)
Definition lsyscache.c:2557
Oid get_func_signature(Oid funcid, Oid **argtypes, int *nargs)
Definition lsyscache.c:2002
Oid get_publication_oid(const char *pubname, bool missing_ok)
Definition lsyscache.c:3978
Oid get_rel_namespace(Oid relid)
Definition lsyscache.c:2258
RegProcedure get_opcode(Oid opno)
Definition lsyscache.c:1577
Oid get_typcollation(Oid typid)
Definition lsyscache.c:3364
Oid get_op_rettype(Oid opno)
Definition lsyscache.c:1625
int get_op_opfamily_strategy(Oid opno, Oid opfamily)
Definition lsyscache.c:87
char * get_collation_name(Oid colloid)
Definition lsyscache.c:1253
Oid get_rel_type_id(Oid relid)
Definition lsyscache.c:2285
char * get_language_name(Oid langoid, bool missing_ok)
Definition lsyscache.c:1405
char * get_namespace_name_or_temp(Oid nspid)
Definition lsyscache.c:3698
void getTypeInputInfo(Oid type, Oid *typInput, Oid *typIOParam)
Definition lsyscache.c:3182
char func_volatile(Oid funcid)
Definition lsyscache.c:2086
bool equality_ops_are_compatible(Oid opno1, Oid opno2)
Definition lsyscache.c:834
bool op_is_safe_index_member(Oid opno)
Definition lsyscache.c:972
bool get_index_isclustered(Oid index_oid)
Definition lsyscache.c:3954
Oid get_opfamily_member(Oid opfamily, Oid lefttype, Oid righttype, int16 strategy)
Definition lsyscache.c:170
char * get_propgraph_label_name(Oid labeloid)
Definition lsyscache.c:4072
Oid get_ordering_op_for_equality_op(Oid opno, bool use_lhs_type)
Definition lsyscache.c:364
Oid get_transform_tosql(Oid typid, Oid langid, List *trftypes)
Definition lsyscache.c:2448
bool func_strict(Oid funcid)
Definition lsyscache.c:2067
Oid get_index_column_opclass(Oid index_oid, int attno)
Definition lsyscache.c:3865
bool get_op_hash_functions_ext(Oid opno, Oid inputtype, RegProcedure *lhs_procno, RegProcedure *rhs_procno)
Definition lsyscache.c:677
char * get_constraint_name(Oid conoid)
Definition lsyscache.c:1299
char * get_attname(Oid relid, AttrNumber attnum, bool missing_ok)
Definition lsyscache.c:1045
bool get_func_leakproof(Oid funcid)
Definition lsyscache.c:2143
Oid get_range_constructor2(Oid rangeOid)
Definition lsyscache.c:3786
Node * get_typdefault(Oid typid)
Definition lsyscache.c:2756
bool get_collation_isdeterministic(Oid colloid)
Definition lsyscache.c:1272
List * get_op_index_interpretation(Oid opno)
Definition lsyscache.c:729
Oid get_subscription_oid(const char *subname, bool missing_ok)
Definition lsyscache.c:4028
char * get_subscription_name(Oid subid, bool missing_ok)
Definition lsyscache.c:4048
Oid get_range_collation(Oid rangeOid)
Definition lsyscache.c:3761
char * get_opfamily_name(Oid opfid, bool missing_ok)
Definition lsyscache.c:1545
char * get_func_name(Oid funcid)
Definition lsyscache.c:1914
Oid get_range_multirange(Oid rangeOid)
Definition lsyscache.c:3811
Oid get_rel_relam(Oid relid)
Definition lsyscache.c:2406
char op_volatile(Oid opno)
Definition lsyscache.c:1799
Oid get_func_namespace(Oid funcid)
Definition lsyscache.c:1938
bool type_is_collatable(Oid typid)
Definition lsyscache.c:3389
Oid get_rel_tablespace(Oid relid)
Definition lsyscache.c:2360
IOFuncSelector
Definition lsyscache.h:35
@ IOFunc_output
Definition lsyscache.h:37
@ IOFunc_input
Definition lsyscache.h:36
@ IOFunc_send
Definition lsyscache.h:39
@ IOFunc_receive
Definition lsyscache.h:38
int get_func_nargs(Oid funcid)
Definition lsyscache.c:1980
void get_type_io_data(Oid typid, IOFuncSelector which_func, int16 *typlen, bool *typbyval, char *typalign, char *typdelim, Oid *typioparam, Oid *func)
Definition lsyscache.c:2631
int16 get_typlen(Oid typid)
Definition lsyscache.c:2503
Oid get_typ_typrelid(Oid typid)
Definition lsyscache.c:3039
char get_typtype(Oid typid)
Definition lsyscache.c:2937
Oid get_base_element_type(Oid typid)
Definition lsyscache.c:3140
Oid getTypeIOParam(HeapTuple typeTuple)
Definition lsyscache.c:2609
Oid get_opfamily_method(Oid opfid)
Definition lsyscache.c:1528
Oid getBaseTypeAndTypmod(Oid typid, int32 *typmod)
Definition lsyscache.c:2846
char * get_qualified_objname(Oid nspid, char *objname)
Definition lsyscache.c:3712
Oid get_transform_fromsql(Oid typid, Oid langid, List *trftypes)
Definition lsyscache.c:2426
char * get_publication_name(Oid pubid, bool missing_ok)
Definition lsyscache.c:3998
Oid getBaseType(Oid typid)
Definition lsyscache.c:2829
bool get_op_hash_functions(Oid opno, RegProcedure *lhs_procno, RegProcedure *rhs_procno)
Definition lsyscache.c:589
bool get_typbyval(Oid typid)
Definition lsyscache.c:2528
bool op_mergejoinable(Oid opno, Oid inputtype)
Definition lsyscache.c:1678
List * get_mergejoin_opfamilies(Oid opno)
Definition lsyscache.c:430
char * get_namespace_name(Oid nspid)
Definition lsyscache.c:3674
Oid get_array_type(Oid typid)
Definition lsyscache.c:3095
Oid get_func_rettype(Oid funcid)
Definition lsyscache.c:1961
Oid get_promoted_array_type(Oid typid)
Definition lsyscache.c:3119
Oid get_atttype(Oid relid, AttrNumber attnum)
Definition lsyscache.c:1131
int32(* get_attavgwidth_hook_type)(Oid relid, AttrNumber attnum)
Definition lsyscache.h:66
char get_constraint_type(Oid conoid)
Definition lsyscache.c:1361
int32 get_typavgwidth(Oid typid, int32 typmod)
Definition lsyscache.c:2886
bool op_in_opfamily(Oid opno, Oid opfamily)
Definition lsyscache.c:70
RegProcedure get_typsubscript(Oid typid, Oid *typelemp)
Definition lsyscache.c:3405
void get_type_category_preferred(Oid typid, char *typcategory, bool *typispreferred)
Definition lsyscache.c:3018
bool get_attstatsslot(AttStatsSlot *sslot, HeapTuple statstuple, int reqkind, Oid reqop, int flags)
Definition lsyscache.c:3542
Oid get_relname_relid(const char *relname, Oid relnamespace)
Definition lsyscache.c:2191
Oid get_negator(Oid opno)
Definition lsyscache.c:1839
Oid get_commutator(Oid opno)
Definition lsyscache.c:1815
void op_input_types(Oid opno, Oid *lefttype, Oid *righttype)
Definition lsyscache.c:1650
bool type_is_multirange(Oid typid)
Definition lsyscache.c:3006
void getTypeBinaryInputInfo(Oid type, Oid *typReceive, Oid *typIOParam)
Definition lsyscache.c:3248
void get_atttypetypmodcoll(Oid relid, AttrNumber attnum, Oid *typid, int32 *typmod, Oid *collid)
Definition lsyscache.c:1161
NameData attname
int16 attnum
NameData relname
Definition pg_class.h:40
NameData subname
char typalign
Definition pg_type.h:178
uint64_t Datum
Definition postgres.h:70
unsigned int Oid
static int fb(int x)
Datum * values
Definition lsyscache.h:54
void * numbers_arr
Definition lsyscache.h:62
float4 * numbers
Definition lsyscache.h:57
void * values_arr
Definition lsyscache.h:61
Definition pg_list.h:54
Definition nodes.h:135
CompareType cmptype
Definition lsyscache.h:28
const char * type