PostgreSQL Source Code git master
Loading...
Searching...
No Matches
parsenodes.h
Go to the documentation of this file.
1/*-------------------------------------------------------------------------
2 *
3 * parsenodes.h
4 * definitions for parse tree nodes
5 *
6 * Many of the node types used in parsetrees include a "location" field.
7 * This is a byte (not character) offset in the original source text, to be
8 * used for positioning an error cursor when there is an error related to
9 * the node. Access to the original source text is needed to make use of
10 * the location. At the topmost (statement) level, we also provide a
11 * statement length, likewise measured in bytes, for convenience in
12 * identifying statement boundaries in multi-statement source strings.
13 *
14 *
15 * Portions Copyright (c) 1996-2026, PostgreSQL Global Development Group
16 * Portions Copyright (c) 1994, Regents of the University of California
17 *
18 * src/include/nodes/parsenodes.h
19 *
20 *-------------------------------------------------------------------------
21 */
22#ifndef PARSENODES_H
23#define PARSENODES_H
24
25#include "common/relpath.h"
26#include "nodes/bitmapset.h"
27#include "nodes/lockoptions.h"
28#include "nodes/primnodes.h"
29#include "nodes/value.h"
31
32
33/* Possible sources of a Query */
34typedef enum QuerySource
35{
36 QSRC_ORIGINAL, /* original parsetree (explicit query) */
37 QSRC_PARSER, /* added by parse analysis (now unused) */
38 QSRC_INSTEAD_RULE, /* added by unconditional INSTEAD rule */
39 QSRC_QUAL_INSTEAD_RULE, /* added by conditional INSTEAD rule */
40 QSRC_NON_INSTEAD_RULE, /* added by non-INSTEAD rule */
42
43/* Sort ordering options for ORDER BY and CREATE INDEX */
44typedef enum SortByDir
45{
49 SORTBY_USING, /* not allowed in CREATE INDEX ... */
51
58
59/* Options for [ ALL | DISTINCT ] */
66
67/*
68 * Grantable rights are encoded so that we can OR them together in a bitmask.
69 * The present representation of AclItem limits us to 32 distinct rights,
70 * even though AclMode is defined as uint64. See utils/acl.h.
71 *
72 * Caution: changing these codes breaks stored ACLs, hence forces initdb.
73 */
74typedef uint64 AclMode; /* a bitmask of privilege bits */
75
76#define ACL_INSERT (1<<0) /* for relations */
77#define ACL_SELECT (1<<1)
78#define ACL_UPDATE (1<<2)
79#define ACL_DELETE (1<<3)
80#define ACL_TRUNCATE (1<<4)
81#define ACL_REFERENCES (1<<5)
82#define ACL_TRIGGER (1<<6)
83#define ACL_EXECUTE (1<<7) /* for functions */
84#define ACL_USAGE (1<<8) /* for various object types */
85#define ACL_CREATE (1<<9) /* for namespaces and databases */
86#define ACL_CREATE_TEMP (1<<10) /* for databases */
87#define ACL_CONNECT (1<<11) /* for databases */
88#define ACL_SET (1<<12) /* for configuration parameters */
89#define ACL_ALTER_SYSTEM (1<<13) /* for configuration parameters */
90#define ACL_MAINTAIN (1<<14) /* for relations */
91#define N_ACL_RIGHTS 15 /* 1 plus the last 1<<x */
92#define ACL_NO_RIGHTS 0
93/* Currently, SELECT ... FOR [KEY] UPDATE/SHARE requires UPDATE privileges */
94#define ACL_SELECT_FOR_UPDATE ACL_UPDATE
95
96
97/*****************************************************************************
98 * Query Tree
99 *****************************************************************************/
100
101/*
102 * Query -
103 * Parse analysis turns all statements into a Query tree
104 * for further processing by the rewriter and planner.
105 *
106 * Utility statements (i.e. non-optimizable statements) have the
107 * utilityStmt field set, and the rest of the Query is mostly dummy.
108 *
109 * Planning converts a Query tree into a Plan tree headed by a PlannedStmt
110 * node --- the Query structure is not used by the executor.
111 *
112 * All the fields ignored for the query jumbling are not semantically
113 * significant (such as alias names), as is ignored anything that can
114 * be deduced from child nodes (else we'd just be double-hashing that
115 * piece of information).
116 */
117typedef struct Query
118{
120
121 CmdType commandType; /* select|insert|update|delete|merge|utility */
122
123 /* where did I come from? */
125
126 /*
127 * query identifier (can be set by plugins); ignored for equal, as it
128 * might not be set; also not stored. This is the result of the query
129 * jumble, hence ignored.
130 *
131 * We store this as a signed value as this is the form it's displayed to
132 * users in places such as EXPLAIN and pg_stat_statements. Primarily this
133 * is done due to lack of an SQL type to represent the full range of
134 * uint64.
135 */
137
138 /* do I set the command result tag? */
140
141 Node *utilityStmt; /* non-null if commandType == CMD_UTILITY */
142
143 /*
144 * rtable index of target relation for INSERT/UPDATE/DELETE/MERGE; 0 for
145 * SELECT. This is ignored in the query jumble as unrelated to the
146 * compilation of the query ID.
147 */
149
150 /* has aggregates in tlist or havingQual */
152 /* has window functions in tlist */
154 /* has set-returning functions in tlist */
156 /* has subquery SubLink */
158 /* distinctClause is from DISTINCT ON */
160 /* WITH RECURSIVE was specified */
162 /* has INSERT/UPDATE/DELETE/MERGE in WITH */
163 bool hasModifyingCTE pg_node_attr(query_jumble_ignore);
164 /* FOR [KEY] UPDATE/SHARE was specified */
166 /* rewriter has applied some RLS policy */
167 bool hasRowSecurity pg_node_attr(query_jumble_ignore);
168 /* parser has added an RTE_GROUP RTE */
170 /* is a RETURN statement */
172
173 List *cteList; /* WITH list (of CommonTableExpr's) */
174
175 List *rtable; /* list of range table entries */
176
177 /*
178 * list of RTEPermissionInfo nodes for the rtable entries having
179 * perminfoindex > 0
180 */
182 FromExpr *jointree; /* table join tree (FROM and WHERE clauses);
183 * also USING clause for MERGE */
184
185 List *mergeActionList; /* list of actions for MERGE (only) */
186
187 /*
188 * rtable index of target relation for MERGE to pull data. Initially, this
189 * is the same as resultRelation, but after query rewriting, if the target
190 * relation is a trigger-updatable view, this is the index of the expanded
191 * view subquery, whereas resultRelation is the index of the target view.
192 */
194
195 /* join condition between source and target for MERGE */
197
198 List *targetList; /* target list (of TargetEntry) */
199
200 /* OVERRIDING clause */
202
203 OnConflictExpr *onConflict; /* ON CONFLICT DO NOTHING/SELECT/UPDATE */
204
205 /*
206 * The following three fields describe the contents of the RETURNING list
207 * for INSERT/UPDATE/DELETE/MERGE. returningOldAlias and returningNewAlias
208 * are the alias names for OLD and NEW, which may be user-supplied values,
209 * the defaults "old" and "new", or NULL (if the default "old"/"new" is
210 * already in use as the alias for some other relation).
211 */
212 char *returningOldAlias pg_node_attr(query_jumble_ignore);
213 char *returningNewAlias pg_node_attr(query_jumble_ignore);
214 List *returningList; /* return-values list (of TargetEntry) */
215
216 List *groupClause; /* a list of SortGroupClause's */
217 bool groupDistinct; /* was GROUP BY DISTINCT used? */
218 bool groupByAll; /* was GROUP BY ALL used? */
219
220 List *groupingSets; /* a list of GroupingSet's if present */
221
222 Node *havingQual; /* qualifications applied to groups */
223
224 List *windowClause; /* a list of WindowClause's */
225
226 List *distinctClause; /* a list of SortGroupClause's */
227
228 List *sortClause; /* a list of SortGroupClause's */
229
230 Node *limitOffset; /* # of result tuples to skip (int8 expr) */
231 Node *limitCount; /* # of result tuples to return (int8 expr) */
232 LimitOption limitOption; /* limit type */
233
234 List *rowMarks; /* a list of RowMarkClause's */
235
236 Node *setOperations; /* set-operation tree if this is top level of
237 * a UNION/INTERSECT/EXCEPT query */
238
239 /*
240 * A list of pg_constraint OIDs that the query depends on to be
241 * semantically valid
242 */
244
245 /* a list of WithCheckOption's (added during rewrite) */
247
248 /*
249 * The following two fields identify the portion of the source text string
250 * containing this query. They are typically only populated in top-level
251 * Queries, not in sub-queries. When not set, they might both be zero, or
252 * both be -1 meaning "unknown".
253 */
254 /* start location, or -1 if unknown */
256 /* length in bytes; 0 means "rest of string" */
259
260
261/****************************************************************************
262 * Supporting data structures for Parse Trees
263 *
264 * Most of these node types appear in raw parsetrees output by the grammar,
265 * and get transformed to something else by the analyzer. A few of them
266 * are used as-is in transformed querytrees.
267 ****************************************************************************/
268
269/*
270 * TypeName - specifies a type in definitions
271 *
272 * For TypeName structures generated internally, it is often easier to
273 * specify the type by OID than by name. If "names" is NIL then the
274 * actual type OID is given by typeOid, otherwise typeOid is unused.
275 * Similarly, if "typmods" is NIL then the actual typmod is expected to
276 * be prespecified in typemod, otherwise typemod is unused.
277 *
278 * If pct_type is true, then names is actually a field name and we look up
279 * the type of that field. Otherwise (the normal case), names is a type
280 * name possibly qualified with schema and database name.
281 */
282typedef struct TypeName
283{
285 List *names; /* qualified name (list of String nodes) */
286 Oid typeOid; /* type identified by OID */
287 bool setof; /* is a set? */
288 bool pct_type; /* %TYPE specified? */
289 List *typmods; /* type modifier expression(s) */
290 int32 typemod; /* prespecified type modifier */
291 List *arrayBounds; /* array bounds */
292 ParseLoc location; /* token location, or -1 if unknown */
294
295/*
296 * ColumnRef - specifies a reference to a column, or possibly a whole tuple
297 *
298 * The "fields" list must be nonempty. It can contain String nodes
299 * (representing names) and A_Star nodes (representing occurrence of a '*').
300 * Currently, A_Star must appear only as the last list element --- the grammar
301 * is responsible for enforcing this!
302 *
303 * Note: any container subscripting or selection of fields from composite columns
304 * is represented by an A_Indirection node above the ColumnRef. However,
305 * for simplicity in the normal case, initial field selection from a table
306 * name is represented within ColumnRef and not by adding A_Indirection.
307 */
308typedef struct ColumnRef
309{
311 List *fields; /* field names (String nodes) or A_Star */
312 ParseLoc location; /* token location, or -1 if unknown */
314
315/*
316 * ParamRef - specifies a $n parameter reference
317 */
318typedef struct ParamRef
319{
321 int number; /* the number of the parameter */
322 ParseLoc location; /* token location, or -1 if unknown */
324
325/*
326 * A_Expr - infix, prefix, and postfix expressions
327 */
328typedef enum A_Expr_Kind
329{
330 AEXPR_OP, /* normal operator */
331 AEXPR_OP_ANY, /* scalar op ANY (array) */
332 AEXPR_OP_ALL, /* scalar op ALL (array) */
333 AEXPR_DISTINCT, /* IS DISTINCT FROM - name must be "=" */
334 AEXPR_NOT_DISTINCT, /* IS NOT DISTINCT FROM - name must be "=" */
335 AEXPR_NULLIF, /* NULLIF - name must be "=" */
336 AEXPR_IN, /* [NOT] IN - name must be "=" or "<>" */
337 AEXPR_LIKE, /* [NOT] LIKE - name must be "~~" or "!~~" */
338 AEXPR_ILIKE, /* [NOT] ILIKE - name must be "~~*" or "!~~*" */
339 AEXPR_SIMILAR, /* [NOT] SIMILAR - name must be "~" or "!~" */
340 AEXPR_BETWEEN, /* name must be "BETWEEN" */
341 AEXPR_NOT_BETWEEN, /* name must be "NOT BETWEEN" */
342 AEXPR_BETWEEN_SYM, /* name must be "BETWEEN SYMMETRIC" */
343 AEXPR_NOT_BETWEEN_SYM, /* name must be "NOT BETWEEN SYMMETRIC" */
345
346typedef struct A_Expr
347{
349
351 A_Expr_Kind kind; /* see above */
352 List *name; /* possibly-qualified name of operator */
353 Node *lexpr; /* left argument, or NULL if none */
354 Node *rexpr; /* right argument, or NULL if none */
355
356 /*
357 * If rexpr is a list of some kind, we separately track its starting and
358 * ending location; it's not the same as the starting and ending location
359 * of the token itself.
360 */
363 ParseLoc location; /* token location, or -1 if unknown */
365
366/*
367 * A_Const - a literal constant
368 *
369 * Value nodes are inline for performance. You can treat 'val' as a node,
370 * as in IsA(&val, Integer). 'val' is not valid if isnull is true.
371 */
381
382typedef struct A_Const
383{
385
388 bool isnull; /* SQL NULL constant */
389 ParseLoc location; /* token location, or -1 if unknown */
391
392/*
393 * TypeCast - a CAST expression
394 */
395typedef struct TypeCast
396{
398 Node *arg; /* the expression being casted */
399 TypeName *typeName; /* the target type */
400 ParseLoc location; /* token location, or -1 if unknown */
402
403/*
404 * CollateClause - a COLLATE expression
405 */
406typedef struct CollateClause
407{
409 Node *arg; /* input expression */
410 List *collname; /* possibly-qualified collation name */
411 ParseLoc location; /* token location, or -1 if unknown */
413
414/*
415 * RoleSpec - a role name or one of a few special values.
416 */
417typedef enum RoleSpecType
418{
419 ROLESPEC_CSTRING, /* role name is stored as a C string */
420 ROLESPEC_CURRENT_ROLE, /* role spec is CURRENT_ROLE */
421 ROLESPEC_CURRENT_USER, /* role spec is CURRENT_USER */
422 ROLESPEC_SESSION_USER, /* role spec is SESSION_USER */
423 ROLESPEC_PUBLIC, /* role name is "public" */
425
426typedef struct RoleSpec
427{
429 RoleSpecType roletype; /* Type of this rolespec */
430 char *rolename; /* filled only for ROLESPEC_CSTRING */
431 ParseLoc location; /* token location, or -1 if unknown */
433
434/*
435 * FuncCall - a function or aggregate invocation
436 *
437 * agg_order (if not NIL) indicates we saw 'foo(... ORDER BY ...)', or if
438 * agg_within_group is true, it was 'foo(...) WITHIN GROUP (ORDER BY ...)'.
439 * agg_star indicates we saw a 'foo(*)' construct, while agg_distinct
440 * indicates we saw 'foo(DISTINCT ...)'. In any of these cases, the
441 * construct *must* be an aggregate call. Otherwise, it might be either an
442 * aggregate or some other kind of function. However, if FILTER or OVER is
443 * present it had better be an aggregate or window function.
444 *
445 * Normally, you'd initialize this via makeFuncCall() and then only change the
446 * parts of the struct its defaults don't match afterwards, as needed.
447 */
448typedef struct FuncCall
449{
451 List *funcname; /* qualified name of function */
452 List *args; /* the arguments (list of exprs) */
453 List *agg_order; /* ORDER BY (list of SortBy) */
454 Node *agg_filter; /* FILTER clause, if any */
455 struct WindowDef *over; /* OVER clause, if any */
456 int ignore_nulls; /* ignore nulls for window function */
457 bool agg_within_group; /* ORDER BY appeared in WITHIN GROUP */
458 bool agg_star; /* argument was really '*' */
459 bool agg_distinct; /* arguments were labeled DISTINCT */
460 bool func_variadic; /* last argument was labeled VARIADIC */
461 CoercionForm funcformat; /* how to display this node */
462 ParseLoc location; /* token location, or -1 if unknown */
464
465/*
466 * A_Star - '*' representing all columns of a table or compound field
467 *
468 * This can appear within ColumnRef.fields, A_Indirection.indirection, and
469 * ResTarget.indirection lists.
470 */
471typedef struct A_Star
472{
475
476/*
477 * A_Indices - array subscript or slice bounds ([idx] or [lidx:uidx])
478 *
479 * In slice case, either or both of lidx and uidx can be NULL (omitted).
480 * In non-slice case, uidx holds the single subscript and lidx is always NULL.
481 */
482typedef struct A_Indices
483{
485 bool is_slice; /* true if slice (i.e., colon present) */
486 Node *lidx; /* slice lower bound, if any */
487 Node *uidx; /* subscript, or slice upper bound if any */
489
490/*
491 * A_Indirection - select a field and/or array element from an expression
492 *
493 * The indirection list can contain A_Indices nodes (representing
494 * subscripting), String nodes (representing field selection --- the
495 * string value is the name of the field to select), and A_Star nodes
496 * (representing selection of all fields of a composite type).
497 * For example, a complex selection operation like
498 * (foo).field1[42][7].field2
499 * would be represented with a single A_Indirection node having a 4-element
500 * indirection list.
501 *
502 * Currently, A_Star must appear only as the last list element --- the grammar
503 * is responsible for enforcing this!
504 */
505typedef struct A_Indirection
506{
508 Node *arg; /* the thing being selected from */
509 List *indirection; /* subscripts and/or field names and/or * */
511
512/*
513 * A_ArrayExpr - an ARRAY[] construct
514 */
515typedef struct A_ArrayExpr
516{
518 List *elements; /* array element expressions */
519 ParseLoc list_start; /* start of the element list */
520 ParseLoc list_end; /* end of the elements list */
521 ParseLoc location; /* token location, or -1 if unknown */
523
524/*
525 * ResTarget -
526 * result target (used in target list of pre-transformed parse trees)
527 *
528 * In a SELECT target list, 'name' is the column label from an
529 * 'AS ColumnLabel' clause, or NULL if there was none, and 'val' is the
530 * value expression itself. The 'indirection' field is not used.
531 *
532 * INSERT uses ResTarget in its target-column-names list. Here, 'name' is
533 * the name of the destination column, 'indirection' stores any subscripts
534 * attached to the destination, and 'val' is not used.
535 *
536 * In an UPDATE target list, 'name' is the name of the destination column,
537 * 'indirection' stores any subscripts attached to the destination, and
538 * 'val' is the expression to assign.
539 *
540 * See A_Indirection for more info about what can appear in 'indirection'.
541 */
542typedef struct ResTarget
543{
545 char *name; /* column name or NULL */
546 List *indirection; /* subscripts, field names, and '*', or NIL */
547 Node *val; /* the value expression to compute or assign */
548 ParseLoc location; /* token location, or -1 if unknown */
550
551/*
552 * MultiAssignRef - element of a row source expression for UPDATE
553 *
554 * In an UPDATE target list, when we have SET (a,b,c) = row-valued-expression,
555 * we generate separate ResTarget items for each of a,b,c. Their "val" trees
556 * are MultiAssignRef nodes numbered 1..n, linking to a common copy of the
557 * row-valued-expression (which parse analysis will process only once, when
558 * handling the MultiAssignRef with colno=1).
559 */
560typedef struct MultiAssignRef
561{
563 Node *source; /* the row-valued expression */
564 int colno; /* column number for this target (1..n) */
565 int ncolumns; /* number of targets in the construct */
567
568/*
569 * SortBy - for ORDER BY clause
570 */
571typedef struct SortBy
572{
574 Node *node; /* expression to sort on */
575 SortByDir sortby_dir; /* ASC/DESC/USING/default */
576 SortByNulls sortby_nulls; /* NULLS FIRST/LAST */
577 List *useOp; /* name of op to use, if SORTBY_USING */
578 ParseLoc location; /* operator location, or -1 if none/unknown */
580
581/*
582 * WindowDef - raw representation of WINDOW and OVER clauses
583 *
584 * For entries in a WINDOW list, "name" is the window name being defined.
585 * For OVER clauses, we use "name" for the "OVER window" syntax, or "refname"
586 * for the "OVER (window)" syntax, which is subtly different --- the latter
587 * implies overriding the window frame clause.
588 */
589typedef struct WindowDef
590{
592 char *name; /* window's own name */
593 char *refname; /* referenced window name, if any */
594 List *partitionClause; /* PARTITION BY expression list */
595 List *orderClause; /* ORDER BY (list of SortBy) */
596 int frameOptions; /* frame_clause options, see below */
597 Node *startOffset; /* expression for starting bound, if any */
598 Node *endOffset; /* expression for ending bound, if any */
599 ParseLoc location; /* parse location, or -1 if none/unknown */
601
602/*
603 * frameOptions is an OR of these bits. The NONDEFAULT and BETWEEN bits are
604 * used so that ruleutils.c can tell which properties were specified and
605 * which were defaulted; the correct behavioral bits must be set either way.
606 * The START_foo and END_foo options must come in pairs of adjacent bits for
607 * the convenience of gram.y, even though some of them are useless/invalid.
608 */
609#define FRAMEOPTION_NONDEFAULT 0x00001 /* any specified? */
610#define FRAMEOPTION_RANGE 0x00002 /* RANGE behavior */
611#define FRAMEOPTION_ROWS 0x00004 /* ROWS behavior */
612#define FRAMEOPTION_GROUPS 0x00008 /* GROUPS behavior */
613#define FRAMEOPTION_BETWEEN 0x00010 /* BETWEEN given? */
614#define FRAMEOPTION_START_UNBOUNDED_PRECEDING 0x00020 /* start is U. P. */
615#define FRAMEOPTION_END_UNBOUNDED_PRECEDING 0x00040 /* (disallowed) */
616#define FRAMEOPTION_START_UNBOUNDED_FOLLOWING 0x00080 /* (disallowed) */
617#define FRAMEOPTION_END_UNBOUNDED_FOLLOWING 0x00100 /* end is U. F. */
618#define FRAMEOPTION_START_CURRENT_ROW 0x00200 /* start is C. R. */
619#define FRAMEOPTION_END_CURRENT_ROW 0x00400 /* end is C. R. */
620#define FRAMEOPTION_START_OFFSET_PRECEDING 0x00800 /* start is O. P. */
621#define FRAMEOPTION_END_OFFSET_PRECEDING 0x01000 /* end is O. P. */
622#define FRAMEOPTION_START_OFFSET_FOLLOWING 0x02000 /* start is O. F. */
623#define FRAMEOPTION_END_OFFSET_FOLLOWING 0x04000 /* end is O. F. */
624#define FRAMEOPTION_EXCLUDE_CURRENT_ROW 0x08000 /* omit C.R. */
625#define FRAMEOPTION_EXCLUDE_GROUP 0x10000 /* omit C.R. & peers */
626#define FRAMEOPTION_EXCLUDE_TIES 0x20000 /* omit C.R.'s peers */
627
628#define FRAMEOPTION_START_OFFSET \
629 (FRAMEOPTION_START_OFFSET_PRECEDING | FRAMEOPTION_START_OFFSET_FOLLOWING)
630#define FRAMEOPTION_END_OFFSET \
631 (FRAMEOPTION_END_OFFSET_PRECEDING | FRAMEOPTION_END_OFFSET_FOLLOWING)
632#define FRAMEOPTION_EXCLUSION \
633 (FRAMEOPTION_EXCLUDE_CURRENT_ROW | FRAMEOPTION_EXCLUDE_GROUP | \
634 FRAMEOPTION_EXCLUDE_TIES)
635
636#define FRAMEOPTION_DEFAULTS \
637 (FRAMEOPTION_RANGE | FRAMEOPTION_START_UNBOUNDED_PRECEDING | \
638 FRAMEOPTION_END_CURRENT_ROW)
639
640/*
641 * RangeSubselect - subquery appearing in a FROM clause
642 */
643typedef struct RangeSubselect
644{
646 bool lateral; /* does it have LATERAL prefix? */
647 Node *subquery; /* the untransformed sub-select clause */
648 Alias *alias; /* table alias & optional column aliases */
650
651/*
652 * RangeFunction - function call appearing in a FROM clause
653 *
654 * functions is a List because we use this to represent the construct
655 * ROWS FROM(func1(...), func2(...), ...). Each element of this list is a
656 * two-element sublist, the first element being the untransformed function
657 * call tree, and the second element being a possibly-empty list of ColumnDef
658 * nodes representing any columndef list attached to that function within the
659 * ROWS FROM() syntax.
660 *
661 * alias and coldeflist represent any alias and/or columndef list attached
662 * at the top level. (We disallow coldeflist appearing both here and
663 * per-function, but that's checked in parse analysis, not by the grammar.)
664 */
665typedef struct RangeFunction
666{
668 bool lateral; /* does it have LATERAL prefix? */
669 bool ordinality; /* does it have WITH ORDINALITY suffix? */
670 bool is_rowsfrom; /* is result of ROWS FROM() syntax? */
671 List *functions; /* per-function information, see above */
672 Alias *alias; /* table alias & optional column aliases */
673 List *coldeflist; /* list of ColumnDef nodes to describe result
674 * of function returning RECORD */
676
677/*
678 * RangeTableFunc - raw form of "table functions" such as XMLTABLE
679 *
680 * Note: JSON_TABLE is also a "table function", but it uses JsonTable node,
681 * not RangeTableFunc.
682 */
683typedef struct RangeTableFunc
684{
686 bool lateral; /* does it have LATERAL prefix? */
687 Node *docexpr; /* document expression */
688 Node *rowexpr; /* row generator expression */
689 List *namespaces; /* list of namespaces as ResTarget */
690 List *columns; /* list of RangeTableFuncCol */
691 Alias *alias; /* table alias & optional column aliases */
692 ParseLoc location; /* token location, or -1 if unknown */
694
695/*
696 * RangeTableFuncCol - one column in a RangeTableFunc->columns
697 *
698 * If for_ordinality is true (FOR ORDINALITY), then the column is an int4
699 * column and the rest of the fields are ignored.
700 */
701typedef struct RangeTableFuncCol
702{
704 char *colname; /* name of generated column */
705 TypeName *typeName; /* type of generated column */
706 bool for_ordinality; /* does it have FOR ORDINALITY? */
707 bool is_not_null; /* does it have NOT NULL? */
708 Node *colexpr; /* column filter expression */
709 Node *coldefexpr; /* column default value expression */
710 ParseLoc location; /* token location, or -1 if unknown */
712
713/*
714 * RangeTableSample - TABLESAMPLE appearing in a raw FROM clause
715 *
716 * This node, appearing only in raw parse trees, represents
717 * <relation> TABLESAMPLE <method> (<params>) REPEATABLE (<num>)
718 * Currently, the <relation> can only be a RangeVar, but we might in future
719 * allow RangeSubselect and other options. Note that the RangeTableSample
720 * is wrapped around the node representing the <relation>, rather than being
721 * a subfield of it.
722 */
723typedef struct RangeTableSample
724{
726 Node *relation; /* relation to be sampled */
727 List *method; /* sampling method name (possibly qualified) */
728 List *args; /* argument(s) for sampling method */
729 Node *repeatable; /* REPEATABLE expression, or NULL if none */
730 ParseLoc location; /* method name location, or -1 if unknown */
732
733/*
734 * ColumnDef - column definition (used in various creates)
735 *
736 * If the column has a default value, we may have the value expression
737 * in either "raw" form (an untransformed parse tree) or "cooked" form
738 * (a post-parse-analysis, executable expression tree), depending on
739 * how this ColumnDef node was created (by parsing, or by inheritance
740 * from an existing relation). We should never have both in the same node!
741 *
742 * Similarly, we may have a COLLATE specification in either raw form
743 * (represented as a CollateClause with arg==NULL) or cooked form
744 * (the collation's OID).
745 *
746 * The constraints list may contain a CONSTR_DEFAULT item in a raw
747 * parsetree produced by gram.y, but transformCreateStmt will remove
748 * the item and set raw_default instead. CONSTR_DEFAULT items
749 * should not appear in any subsequent processing.
750 */
751typedef struct ColumnDef
752{
754 char *colname; /* name of column */
755 TypeName *typeName; /* type of column */
756 char *compression; /* compression method for column */
757 int16 inhcount; /* number of times column is inherited */
758 bool is_local; /* column has local (non-inherited) def'n */
759 bool is_not_null; /* NOT NULL constraint specified? */
760 bool is_from_type; /* column definition came from table type */
761 char storage; /* attstorage setting, or 0 for default */
762 char *storage_name; /* attstorage setting name or NULL for default */
763 Node *raw_default; /* default value (untransformed parse tree) */
764 Node *cooked_default; /* default value (transformed expr tree) */
765 char identity; /* attidentity setting */
766 RangeVar *identitySequence; /* to store identity sequence name for
767 * ALTER TABLE ... ADD COLUMN */
768 char generated; /* attgenerated setting */
769 CollateClause *collClause; /* untransformed COLLATE spec, if any */
770 Oid collOid; /* collation OID (InvalidOid if not set) */
771 List *constraints; /* other constraints on column */
772 List *fdwoptions; /* per-column FDW options */
773 ParseLoc location; /* parse location, or -1 if none/unknown */
775
776/*
777 * TableLikeClause - CREATE TABLE ( ... LIKE ... ) clause
778 */
779typedef struct TableLikeClause
780{
783 bits32 options; /* OR of TableLikeOption flags */
784 Oid relationOid; /* If table has been looked up, its OID */
786
800
801/*
802 * IndexElem - index parameters (used in CREATE INDEX, and in ON CONFLICT)
803 *
804 * For a plain index attribute, 'name' is the name of the table column to
805 * index, and 'expr' is NULL. For an index expression, 'name' is NULL and
806 * 'expr' is the expression tree.
807 */
808typedef struct IndexElem
809{
811 char *name; /* name of attribute to index, or NULL */
812 Node *expr; /* expression to index, or NULL */
813 char *indexcolname; /* name for index column; NULL = default */
814 List *collation; /* name of collation; NIL = default */
815 List *opclass; /* name of desired opclass; NIL = default */
816 List *opclassopts; /* opclass-specific options, or NIL */
817 SortByDir ordering; /* ASC/DESC/default */
818 SortByNulls nulls_ordering; /* FIRST/LAST/default */
819 ParseLoc location; /* token location, or -1 if unknown */
821
822/*
823 * DefElem - a generic "name = value" option definition
824 *
825 * In some contexts the name can be qualified. Also, certain SQL commands
826 * allow a SET/ADD/DROP action to be attached to option settings, so it's
827 * convenient to carry a field for that too. (Note: currently, it is our
828 * practice that the grammar allows namespace and action only in statements
829 * where they are relevant; C code can just ignore those fields in other
830 * statements.)
831 */
839
840typedef struct DefElem
841{
843 char *defnamespace; /* NULL if unqualified name */
844 char *defname;
845 Node *arg; /* typically Integer, Float, String, or
846 * TypeName */
847 DefElemAction defaction; /* unspecified action, or SET/ADD/DROP */
848 ParseLoc location; /* token location, or -1 if unknown */
850
851/*
852 * LockingClause - raw representation of FOR [NO KEY] UPDATE/[KEY] SHARE
853 * options
854 *
855 * Note: lockedRels == NIL means "all relations in query". Otherwise it
856 * is a list of RangeVar nodes. (We use RangeVar mainly because it carries
857 * a location field --- currently, parse analysis insists on unqualified
858 * names in LockingClause.)
859 */
860typedef struct LockingClause
861{
863 List *lockedRels; /* FOR [KEY] UPDATE/SHARE relations */
865 LockWaitPolicy waitPolicy; /* NOWAIT and SKIP LOCKED */
867
868/*
869 * XMLSERIALIZE (in raw parse tree only)
870 */
871typedef struct XmlSerialize
872{
874 XmlOptionType xmloption; /* DOCUMENT or CONTENT */
877 bool indent; /* [NO] INDENT */
878 ParseLoc location; /* token location, or -1 if unknown */
880
881/* Partitioning related definitions */
882
883/*
884 * PartitionElem - parse-time representation of a single partition key
885 *
886 * expr can be either a raw expression tree or a parse-analyzed expression.
887 * We don't store these on-disk, though.
888 */
889typedef struct PartitionElem
890{
892 char *name; /* name of column to partition on, or NULL */
893 Node *expr; /* expression to partition on, or NULL */
894 List *collation; /* name of collation; NIL = default */
895 List *opclass; /* name of desired opclass; NIL = default */
896 ParseLoc location; /* token location, or -1 if unknown */
898
905
906/*
907 * PartitionSpec - parse-time representation of a partition key specification
908 *
909 * This represents the key space we will be partitioning on.
910 */
911typedef struct PartitionSpec
912{
915 List *partParams; /* List of PartitionElems */
916 ParseLoc location; /* token location, or -1 if unknown */
918
919/*
920 * PartitionBoundSpec - a partition bound specification
921 *
922 * This represents the portion of the partition key space assigned to a
923 * particular partition. These are stored on disk in pg_class.relpartbound.
924 */
926{
928
929 char strategy; /* see PARTITION_STRATEGY codes above */
930 bool is_default; /* is it a default partition bound? */
931
932 /* Partitioning info for HASH strategy: */
935
936 /* Partitioning info for LIST strategy: */
937 List *listdatums; /* List of Consts (or A_Consts in raw tree) */
938
939 /* Partitioning info for RANGE strategy: */
940 List *lowerdatums; /* List of PartitionRangeDatums */
941 List *upperdatums; /* List of PartitionRangeDatums */
942
943 ParseLoc location; /* token location, or -1 if unknown */
944};
945
946/*
947 * PartitionRangeDatum - one of the values in a range partition bound
948 *
949 * This can be MINVALUE, MAXVALUE or a specific bounded value.
950 */
952{
953 PARTITION_RANGE_DATUM_MINVALUE = -1, /* less than any other value */
954 PARTITION_RANGE_DATUM_VALUE = 0, /* a specific (bounded) value */
955 PARTITION_RANGE_DATUM_MAXVALUE = 1, /* greater than any other value */
957
959{
961
963 Node *value; /* Const (or A_Const in raw tree), if kind is
964 * PARTITION_RANGE_DATUM_VALUE, else NULL */
965
966 ParseLoc location; /* token location, or -1 if unknown */
968
969/*
970 * PartitionDesc - info about a single partition for the ALTER TABLE SPLIT
971 * PARTITION command
972 */
974{
976
977 RangeVar *name; /* name of partition */
978 PartitionBoundSpec *bound; /* FOR VALUES, if attaching */
980
981/*
982 * PartitionCmd - info for ALTER TABLE/INDEX ATTACH/DETACH PARTITION and for
983 * ALTER TABLE SPLIT/MERGE PARTITION(S) commands
984 */
985typedef struct PartitionCmd
986{
988
989 /* name of partition to attach/detach/merge/split */
991
992 /* FOR VALUES, if attaching */
994
995 /*
996 * list of partitions to be split/merged, used in ALTER TABLE MERGE
997 * PARTITIONS and ALTER TABLE SPLIT PARTITIONS. For merge partitions,
998 * partlist is a list of RangeVar; For split partition, it is a list of
999 * SinglePartitionSpec.
1000 */
1002
1005
1006/****************************************************************************
1007 * Nodes for a Query tree
1008 ****************************************************************************/
1009
1010/*--------------------
1011 * RangeTblEntry -
1012 * A range table is a List of RangeTblEntry nodes.
1013 *
1014 * A range table entry may represent a plain relation, a sub-select in
1015 * FROM, or the result of a JOIN clause. (Only explicit JOIN syntax
1016 * produces an RTE, not the implicit join resulting from multiple FROM
1017 * items. This is because we only need the RTE to deal with SQL features
1018 * like outer joins and join-output-column aliasing.) Other special
1019 * RTE types also exist, as indicated by RTEKind.
1020 *
1021 * Note that we consider RTE_RELATION to cover anything that has a pg_class
1022 * entry. relkind distinguishes the sub-cases.
1023 *
1024 * alias is an Alias node representing the AS alias-clause attached to the
1025 * FROM expression, or NULL if no clause.
1026 *
1027 * eref is the table reference name and column reference names (either
1028 * real or aliases). Note that system columns (OID etc) are not included
1029 * in the column list.
1030 * eref->aliasname is required to be present, and should generally be used
1031 * to identify the RTE for error messages etc.
1032 *
1033 * In RELATION RTEs, the colnames in both alias and eref are indexed by
1034 * physical attribute number; this means there must be colname entries for
1035 * dropped columns. When building an RTE we insert empty strings ("") for
1036 * dropped columns. Note however that a stored rule may have nonempty
1037 * colnames for columns dropped since the rule was created (and for that
1038 * matter the colnames might be out of date due to column renamings).
1039 * The same comments apply to FUNCTION RTEs when a function's return type
1040 * is a named composite type.
1041 *
1042 * In JOIN RTEs, the colnames in both alias and eref are one-to-one with
1043 * joinaliasvars entries. A JOIN RTE will omit columns of its inputs when
1044 * those columns are known to be dropped at parse time. Again, however,
1045 * a stored rule might contain entries for columns dropped since the rule
1046 * was created. (This is only possible for columns not actually referenced
1047 * in the rule.) When loading a stored rule, we replace the joinaliasvars
1048 * items for any such columns with null pointers. (We can't simply delete
1049 * them from the joinaliasvars list, because that would affect the attnums
1050 * of Vars referencing the rest of the list.)
1051 *
1052 * inFromCl marks those range variables that are listed in the FROM clause.
1053 * It's false for RTEs that are added to a query behind the scenes, such
1054 * as the NEW and OLD variables for a rule, or the subqueries of a UNION.
1055 * This flag is not used during parsing (except in transformLockingClause,
1056 * q.v.); the parser now uses a separate "namespace" data structure to
1057 * control visibility. But it is needed by ruleutils.c to determine
1058 * whether RTEs should be shown in decompiled queries.
1059 *
1060 * securityQuals is a list of security barrier quals (boolean expressions),
1061 * to be tested in the listed order before returning a row from the
1062 * relation. It is always NIL in parser output. Entries are added by the
1063 * rewriter to implement security-barrier views and/or row-level security.
1064 * Note that the planner turns each boolean expression into an implicitly
1065 * AND'ed sublist, as is its usual habit with qualification expressions.
1066 *--------------------
1067 */
1068typedef enum RTEKind
1069{
1070 RTE_RELATION, /* ordinary relation reference */
1071 RTE_SUBQUERY, /* subquery in FROM */
1072 RTE_JOIN, /* join */
1073 RTE_FUNCTION, /* function in FROM */
1074 RTE_TABLEFUNC, /* TableFunc(.., column list) */
1075 RTE_VALUES, /* VALUES (<exprlist>), (<exprlist>), ... */
1076 RTE_CTE, /* common table expr (WITH list element) */
1077 RTE_NAMEDTUPLESTORE, /* tuplestore, e.g. for AFTER triggers */
1078 RTE_RESULT, /* RTE represents an empty FROM clause; such
1079 * RTEs are added by the planner, they're not
1080 * present during parsing or rewriting */
1081 RTE_GROUP, /* the grouping step */
1083
1084typedef struct RangeTblEntry
1085{
1087
1088 NodeTag type;
1089
1090 /*
1091 * Fields valid in all RTEs:
1092 *
1093 * put alias + eref first to make dump more legible
1094 */
1095 /* user-written alias clause, if any */
1097
1098 /*
1099 * Expanded reference names. This uses a custom query jumble function so
1100 * that the table name is included in the computation, but not its list of
1101 * columns.
1102 */
1104
1105 RTEKind rtekind; /* see above */
1106
1107 /*
1108 * Fields valid for a plain relation RTE (else zero):
1109 *
1110 * inh is true for relation references that should be expanded to include
1111 * inheritance children, if the rel has any. In the parser, this will
1112 * only be true for RTE_RELATION entries. The planner also uses this
1113 * field to mark RTE_SUBQUERY entries that contain UNION ALL queries that
1114 * it has flattened into pulled-up subqueries (creating a structure much
1115 * like the effects of inheritance).
1116 *
1117 * rellockmode is really LOCKMODE, but it's declared int to avoid having
1118 * to include lock-related headers here. It must be RowExclusiveLock if
1119 * the RTE is an INSERT/UPDATE/DELETE/MERGE target, else RowShareLock if
1120 * the RTE is a SELECT FOR UPDATE/FOR SHARE target, else AccessShareLock.
1121 *
1122 * Note: in some cases, rule expansion may result in RTEs that are marked
1123 * with RowExclusiveLock even though they are not the target of the
1124 * current query; this happens if a DO ALSO rule simply scans the original
1125 * target table. We leave such RTEs with their original lockmode so as to
1126 * avoid getting an additional, lesser lock.
1127 *
1128 * perminfoindex is 1-based index of the RTEPermissionInfo belonging to
1129 * this RTE in the containing struct's list of same; 0 if permissions need
1130 * not be checked for this RTE.
1131 *
1132 * As a special case, relid, relkind, rellockmode, and perminfoindex can
1133 * also be set (nonzero) in an RTE_SUBQUERY RTE. This occurs when we
1134 * convert an RTE_RELATION RTE naming a view into an RTE_SUBQUERY
1135 * containing the view's query. We still need to perform run-time locking
1136 * and permission checks on the view, even though it's not directly used
1137 * in the query anymore, and the most expedient way to do that is to
1138 * retain these fields from the old state of the RTE.
1139 *
1140 * As a special case, RTE_NAMEDTUPLESTORE can also set relid to indicate
1141 * that the tuple format of the tuplestore is the same as the referenced
1142 * relation. This allows plans referencing AFTER trigger transition
1143 * tables to be invalidated if the underlying table is altered.
1144 */
1145 /* OID of the relation */
1147 /* inheritance requested? */
1148 bool inh;
1149 /* relation kind (see pg_class.relkind) */
1151 /* lock level that query requires on the rel */
1153 /* index of RTEPermissionInfo entry, or 0 */
1155 /* sampling info, or NULL */
1157
1158 /*
1159 * Fields valid for a subquery RTE (else NULL):
1160 */
1161 /* the sub-query */
1163 /* is from security_barrier view? */
1164 bool security_barrier pg_node_attr(query_jumble_ignore);
1165
1166 /*
1167 * Fields valid for a join RTE (else NULL/zero):
1168 *
1169 * joinaliasvars is a list of (usually) Vars corresponding to the columns
1170 * of the join result. An alias Var referencing column K of the join
1171 * result can be replaced by the K'th element of joinaliasvars --- but to
1172 * simplify the task of reverse-listing aliases correctly, we do not do
1173 * that until planning time. In detail: an element of joinaliasvars can
1174 * be a Var of one of the join's input relations, or such a Var with an
1175 * implicit coercion to the join's output column type, or a COALESCE
1176 * expression containing the two input column Vars (possibly coerced).
1177 * Elements beyond the first joinmergedcols entries are always just Vars,
1178 * and are never referenced from elsewhere in the query (that is, join
1179 * alias Vars are generated only for merged columns). We keep these
1180 * entries only because they're needed in expandRTE() and similar code.
1181 *
1182 * Vars appearing within joinaliasvars are marked with varnullingrels sets
1183 * that describe the nulling effects of this join and lower ones. This is
1184 * essential for FULL JOIN cases, because the COALESCE expression only
1185 * describes the semantics correctly if its inputs have been nulled by the
1186 * join. For other cases, it allows expandRTE() to generate a valid
1187 * representation of the join's output without consulting additional
1188 * parser state.
1189 *
1190 * Within a Query loaded from a stored rule, it is possible for non-merged
1191 * joinaliasvars items to be null pointers, which are placeholders for
1192 * (necessarily unreferenced) columns dropped since the rule was made.
1193 * Also, once planning begins, joinaliasvars items can be almost anything,
1194 * as a result of subquery-flattening substitutions.
1195 *
1196 * joinleftcols is an integer list of physical column numbers of the left
1197 * join input rel that are included in the join; likewise joinrighttcols
1198 * for the right join input rel. (Which rels those are can be determined
1199 * from the associated JoinExpr.) If the join is USING/NATURAL, then the
1200 * first joinmergedcols entries in each list identify the merged columns.
1201 * The merged columns come first in the join output, then remaining
1202 * columns of the left input, then remaining columns of the right.
1203 *
1204 * Note that input columns could have been dropped after creation of a
1205 * stored rule, if they are not referenced in the query (in particular,
1206 * merged columns could not be dropped); this is not accounted for in
1207 * joinleftcols/joinrighttcols.
1208 */
1210 /* number of merged (JOIN USING) columns */
1212 /* list of alias-var expansions */
1214 /* left-side input column numbers */
1216 /* right-side input column numbers */
1218
1219 /*
1220 * join_using_alias is an alias clause attached directly to JOIN/USING. It
1221 * is different from the alias field (above) in that it does not hide the
1222 * range variables of the tables being joined.
1223 */
1225
1226 /*
1227 * Fields valid for a function RTE (else NIL/zero):
1228 *
1229 * When funcordinality is true, the eref->colnames list includes an alias
1230 * for the ordinality column. The ordinality column is otherwise
1231 * implicit, and must be accounted for "by hand" in places such as
1232 * expandRTE().
1233 */
1234 /* list of RangeTblFunction nodes */
1236 /* is this called WITH ORDINALITY? */
1238
1239 /*
1240 * Fields valid for a TableFunc RTE (else NULL):
1241 */
1243
1244 /*
1245 * Fields valid for a values RTE (else NIL):
1246 */
1247 /* list of expression lists */
1249
1250 /*
1251 * Fields valid for a CTE RTE (else NULL/zero):
1252 */
1253 /* name of the WITH list item */
1254 char *ctename;
1255 /* number of query levels up */
1257 /* is this a recursive self-reference? */
1259
1260 /*
1261 * Fields valid for CTE, VALUES, ENR, and TableFunc RTEs (else NIL):
1262 *
1263 * We need these for CTE RTEs so that the types of self-referential
1264 * columns are well-defined. For VALUES RTEs, storing these explicitly
1265 * saves having to re-determine the info by scanning the values_lists. For
1266 * ENRs, we store the types explicitly here (we could get the information
1267 * from the catalogs if 'relid' was supplied, but we'd still need these
1268 * for TupleDesc-based ENRs, so we might as well always store the type
1269 * info here). For TableFuncs, these fields are redundant with data in
1270 * the TableFunc node, but keeping them here allows some code sharing with
1271 * the other cases.
1272 *
1273 * For ENRs only, we have to consider the possibility of dropped columns.
1274 * A dropped column is included in these lists, but it will have zeroes in
1275 * all three lists (as well as an empty-string entry in eref). Testing
1276 * for zero coltype is the standard way to detect a dropped column.
1277 */
1278 /* OID list of column type OIDs */
1280 /* integer list of column typmods */
1282 /* OID list of column collation OIDs */
1284
1285 /*
1286 * Fields valid for ENR RTEs (else NULL/zero):
1287 */
1288 /* name of ephemeral named relation */
1289 char *enrname;
1290 /* estimated or actual from caller */
1292
1293 /*
1294 * Fields valid for a GROUP RTE (else NIL):
1295 */
1296 /* list of grouping expressions */
1298
1299 /*
1300 * Fields valid in all RTEs:
1301 */
1302 /* was LATERAL specified? */
1304 /* present in FROM clause? */
1306 /* security barrier quals to apply, if any */
1309
1310/*
1311 * RTEPermissionInfo
1312 * Per-relation information for permission checking. Added to the Query
1313 * node by the parser when adding the corresponding RTE to the query
1314 * range table and subsequently editorialized on by the rewriter if
1315 * needed after rule expansion.
1316 *
1317 * Only the relations directly mentioned in the query are checked for
1318 * access permissions by the core executor, so only their RTEPermissionInfos
1319 * are present in the Query. However, extensions may want to check inheritance
1320 * children too, depending on the value of rte->inh, so it's copied in 'inh'
1321 * for their perusal.
1322 *
1323 * requiredPerms and checkAsUser specify run-time access permissions checks
1324 * to be performed at query startup. The user must have *all* of the
1325 * permissions that are OR'd together in requiredPerms (never 0!). If
1326 * checkAsUser is not zero, then do the permissions checks using the access
1327 * rights of that user, not the current effective user ID. (This allows rules
1328 * to act as setuid gateways.)
1329 *
1330 * For SELECT/INSERT/UPDATE permissions, if the user doesn't have table-wide
1331 * permissions then it is sufficient to have the permissions on all columns
1332 * identified in selectedCols (for SELECT) and/or insertedCols and/or
1333 * updatedCols (INSERT with ON CONFLICT DO UPDATE may have all 3).
1334 * selectedCols, insertedCols and updatedCols are bitmapsets, which cannot have
1335 * negative integer members, so we subtract FirstLowInvalidHeapAttributeNumber
1336 * from column numbers before storing them in these fields. A whole-row Var
1337 * reference is represented by setting the bit for InvalidAttrNumber.
1338 *
1339 * updatedCols is also used in some other places, for example, to determine
1340 * which triggers to fire and in FDWs to know which changed columns they need
1341 * to ship off.
1342 */
1343typedef struct RTEPermissionInfo
1344{
1346
1347 Oid relid; /* relation OID */
1348 bool inh; /* separately check inheritance children? */
1349 AclMode requiredPerms; /* bitmask of required access permissions */
1350 Oid checkAsUser; /* if valid, check access as this role */
1351 Bitmapset *selectedCols; /* columns needing SELECT permission */
1352 Bitmapset *insertedCols; /* columns needing INSERT permission */
1353 Bitmapset *updatedCols; /* columns needing UPDATE permission */
1355
1356/*
1357 * RangeTblFunction -
1358 * RangeTblEntry subsidiary data for one function in a FUNCTION RTE.
1359 *
1360 * If the function had a column definition list (required for an
1361 * otherwise-unspecified RECORD result), funccolnames lists the names given
1362 * in the definition list, funccoltypes lists their declared column types,
1363 * funccoltypmods lists their typmods, funccolcollations their collations.
1364 * Otherwise, those fields are NIL.
1365 *
1366 * Notice we don't attempt to store info about the results of functions
1367 * returning named composite types, because those can change from time to
1368 * time. We do however remember how many columns we thought the type had
1369 * (including dropped columns!), so that we can successfully ignore any
1370 * columns added after the query was parsed.
1371 *
1372 * The query jumbling only needs to track the function expression.
1373 */
1374typedef struct RangeTblFunction
1375{
1377
1378 Node *funcexpr; /* expression tree for func call */
1379 /* number of columns it contributes to RTE */
1381 /* These fields record the contents of a column definition list, if any: */
1382 /* column names (list of String) */
1384 /* OID list of column type OIDs */
1386 /* integer list of column typmods */
1388 /* OID list of column collation OIDs */
1390
1391 /* This is set during planning for use by the executor: */
1392 /* PARAM_EXEC Param IDs affecting this func */
1395
1396/*
1397 * TableSampleClause - TABLESAMPLE appearing in a transformed FROM clause
1398 *
1399 * Unlike RangeTableSample, this is a subnode of the relevant RangeTblEntry.
1400 */
1401typedef struct TableSampleClause
1402{
1404 Oid tsmhandler; /* OID of the tablesample handler function */
1405 List *args; /* tablesample argument expression(s) */
1406 Expr *repeatable; /* REPEATABLE expression, or NULL if none */
1408
1409/*
1410 * WithCheckOption -
1411 * representation of WITH CHECK OPTION checks to be applied to new tuples
1412 * when inserting/updating an auto-updatable view, or RLS WITH CHECK
1413 * policies to be applied when inserting/updating a relation with RLS.
1414 */
1415typedef enum WCOKind
1416{
1417 WCO_VIEW_CHECK, /* WCO on an auto-updatable view */
1418 WCO_RLS_INSERT_CHECK, /* RLS INSERT WITH CHECK policy */
1419 WCO_RLS_UPDATE_CHECK, /* RLS UPDATE WITH CHECK policy */
1420 WCO_RLS_CONFLICT_CHECK, /* RLS ON CONFLICT DO SELECT/UPDATE USING
1421 * policy */
1422 WCO_RLS_MERGE_UPDATE_CHECK, /* RLS MERGE UPDATE USING policy */
1423 WCO_RLS_MERGE_DELETE_CHECK, /* RLS MERGE DELETE USING policy */
1425
1426typedef struct WithCheckOption
1427{
1429 WCOKind kind; /* kind of WCO */
1430 char *relname; /* name of relation that specified the WCO */
1431 char *polname; /* name of RLS policy being checked */
1432 Node *qual; /* constraint qual to check */
1433 bool cascaded; /* true for a cascaded WCO on a view */
1435
1436/*
1437 * SortGroupClause -
1438 * representation of ORDER BY, GROUP BY, PARTITION BY,
1439 * DISTINCT, DISTINCT ON items
1440 *
1441 * You might think that ORDER BY is only interested in defining ordering,
1442 * and GROUP/DISTINCT are only interested in defining equality. However,
1443 * one way to implement grouping is to sort and then apply a "uniq"-like
1444 * filter. So it's also interesting to keep track of possible sort operators
1445 * for GROUP/DISTINCT, and in particular to try to sort for the grouping
1446 * in a way that will also yield a requested ORDER BY ordering. So we need
1447 * to be able to compare ORDER BY and GROUP/DISTINCT lists, which motivates
1448 * the decision to give them the same representation.
1449 *
1450 * tleSortGroupRef must match ressortgroupref of exactly one entry of the
1451 * query's targetlist; that is the expression to be sorted or grouped by.
1452 * eqop is the OID of the equality operator.
1453 * sortop is the OID of the ordering operator (a "<" or ">" operator),
1454 * or InvalidOid if not available.
1455 * nulls_first means about what you'd expect. If sortop is InvalidOid
1456 * then nulls_first is meaningless and should be set to false.
1457 * hashable is true if eqop is hashable (note this condition also depends
1458 * on the datatype of the input expression).
1459 *
1460 * In an ORDER BY item, all fields must be valid. (The eqop isn't essential
1461 * here, but it's cheap to get it along with the sortop, and requiring it
1462 * to be valid eases comparisons to grouping items.) Note that this isn't
1463 * actually enough information to determine an ordering: if the sortop is
1464 * collation-sensitive, a collation OID is needed too. We don't store the
1465 * collation in SortGroupClause because it's not available at the time the
1466 * parser builds the SortGroupClause; instead, consult the exposed collation
1467 * of the referenced targetlist expression to find out what it is.
1468 *
1469 * In a grouping item, eqop must be valid. If the eqop is a btree equality
1470 * operator, then sortop should be set to a compatible ordering operator.
1471 * We prefer to set eqop/sortop/nulls_first to match any ORDER BY item that
1472 * the query presents for the same tlist item. If there is none, we just
1473 * use the default ordering op for the datatype.
1474 *
1475 * If the tlist item's type has a hash opclass but no btree opclass, then
1476 * we will set eqop to the hash equality operator, sortop to InvalidOid,
1477 * and nulls_first to false. A grouping item of this kind can only be
1478 * implemented by hashing, and of course it'll never match an ORDER BY item.
1479 *
1480 * The hashable flag is provided since we generally have the requisite
1481 * information readily available when the SortGroupClause is constructed,
1482 * and it's relatively expensive to get it again later. Note there is no
1483 * need for a "sortable" flag since OidIsValid(sortop) serves the purpose.
1484 *
1485 * A query might have both ORDER BY and DISTINCT (or DISTINCT ON) clauses.
1486 * In SELECT DISTINCT, the distinctClause list is as long or longer than the
1487 * sortClause list, while in SELECT DISTINCT ON it's typically shorter.
1488 * The two lists must match up to the end of the shorter one --- the parser
1489 * rearranges the distinctClause if necessary to make this true. (This
1490 * restriction ensures that only one sort step is needed to both satisfy the
1491 * ORDER BY and set up for the Unique step. This is semantically necessary
1492 * for DISTINCT ON, and presents no real drawback for DISTINCT.)
1493 */
1494typedef struct SortGroupClause
1495{
1497 Index tleSortGroupRef; /* reference into targetlist */
1498 Oid eqop; /* the equality operator ('=' op) */
1499 Oid sortop; /* the ordering operator ('<' op), or 0 */
1500 bool reverse_sort; /* is sortop a "greater than" operator? */
1501 bool nulls_first; /* do NULLs come before normal values? */
1502 /* can eqop be implemented by hashing? */
1505
1506/*
1507 * GroupingSet -
1508 * representation of CUBE, ROLLUP and GROUPING SETS clauses
1509 *
1510 * In a Query with grouping sets, the groupClause contains a flat list of
1511 * SortGroupClause nodes for each distinct expression used. The actual
1512 * structure of the GROUP BY clause is given by the groupingSets tree.
1513 *
1514 * In the raw parser output, GroupingSet nodes (of all types except SIMPLE
1515 * which is not used) are potentially mixed in with the expressions in the
1516 * groupClause of the SelectStmt. (An expression can't contain a GroupingSet,
1517 * but a list may mix GroupingSet and expression nodes.) At this stage, the
1518 * content of each node is a list of expressions, some of which may be RowExprs
1519 * which represent sublists rather than actual row constructors, and nested
1520 * GroupingSet nodes where legal in the grammar. The structure directly
1521 * reflects the query syntax.
1522 *
1523 * In parse analysis, the transformed expressions are used to build the tlist
1524 * and groupClause list (of SortGroupClause nodes), and the groupingSets tree
1525 * is eventually reduced to a fixed format:
1526 *
1527 * EMPTY nodes represent (), and obviously have no content
1528 *
1529 * SIMPLE nodes represent a list of one or more expressions to be treated as an
1530 * atom by the enclosing structure; the content is an integer list of
1531 * ressortgroupref values (see SortGroupClause)
1532 *
1533 * CUBE and ROLLUP nodes contain a list of one or more SIMPLE nodes.
1534 *
1535 * SETS nodes contain a list of EMPTY, SIMPLE, CUBE or ROLLUP nodes, but after
1536 * parse analysis they cannot contain more SETS nodes; enough of the syntactic
1537 * transforms of the spec have been applied that we no longer have arbitrarily
1538 * deep nesting (though we still preserve the use of cube/rollup).
1539 *
1540 * Note that if the groupingSets tree contains no SIMPLE nodes (only EMPTY
1541 * nodes at the leaves), then the groupClause will be empty, but this is still
1542 * an aggregation query (similar to using aggs or HAVING without GROUP BY).
1543 *
1544 * As an example, the following clause:
1545 *
1546 * GROUP BY GROUPING SETS ((a,b), CUBE(c,(d,e)))
1547 *
1548 * looks like this after raw parsing:
1549 *
1550 * SETS( RowExpr(a,b) , CUBE( c, RowExpr(d,e) ) )
1551 *
1552 * and parse analysis converts it to:
1553 *
1554 * SETS( SIMPLE(1,2), CUBE( SIMPLE(3), SIMPLE(4,5) ) )
1555 */
1564
1572
1573/*
1574 * WindowClause -
1575 * transformed representation of WINDOW and OVER clauses
1576 *
1577 * A parsed Query's windowClause list contains these structs. "name" is set
1578 * if the clause originally came from WINDOW, and is NULL if it originally
1579 * was an OVER clause (but note that we collapse out duplicate OVERs).
1580 * partitionClause and orderClause are lists of SortGroupClause structs.
1581 * partitionClause is sanitized by the query planner to remove any columns or
1582 * expressions belonging to redundant PathKeys.
1583 * If we have RANGE with offset PRECEDING/FOLLOWING, the semantics of that are
1584 * specified by startInRangeFunc/inRangeColl/inRangeAsc/inRangeNullsFirst
1585 * for the start offset, or endInRangeFunc/inRange* for the end offset.
1586 * winref is an ID number referenced by WindowFunc nodes; it must be unique
1587 * among the members of a Query's windowClause list.
1588 * When refname isn't null, the partitionClause is always copied from there;
1589 * the orderClause might or might not be copied (see copiedOrder); the framing
1590 * options are never copied, per spec.
1591 *
1592 * The information relevant for the query jumbling is the partition clause
1593 * type and its bounds.
1594 */
1595typedef struct WindowClause
1596{
1598 /* window name (NULL in an OVER clause) */
1600 /* referenced window name, if any */
1602 List *partitionClause; /* PARTITION BY list */
1603 /* ORDER BY list */
1605 int frameOptions; /* frame_clause options, see WindowDef */
1606 Node *startOffset; /* expression for starting bound, if any */
1607 Node *endOffset; /* expression for ending bound, if any */
1608 /* in_range function for startOffset */
1610 /* in_range function for endOffset */
1612 /* collation for in_range tests */
1614 /* use ASC sort order for in_range tests? */
1616 /* nulls sort first for in_range tests? */
1617 bool inRangeNullsFirst pg_node_attr(query_jumble_ignore);
1618 Index winref; /* ID referenced by window functions */
1619 /* did we copy orderClause from refname? */
1622
1623/*
1624 * RowMarkClause -
1625 * parser output representation of FOR [KEY] UPDATE/SHARE clauses
1626 *
1627 * Query.rowMarks contains a separate RowMarkClause node for each relation
1628 * identified as a FOR [KEY] UPDATE/SHARE target. If one of these clauses
1629 * is applied to a subquery, we generate RowMarkClauses for all normal and
1630 * subquery rels in the subquery, but they are marked pushedDown = true to
1631 * distinguish them from clauses that were explicitly written at this query
1632 * level. Also, Query.hasForUpdate tells whether there were explicit FOR
1633 * UPDATE/SHARE/KEY SHARE clauses in the current query level.
1634 */
1635typedef struct RowMarkClause
1636{
1638 Index rti; /* range table index of target relation */
1640 LockWaitPolicy waitPolicy; /* NOWAIT and SKIP LOCKED */
1641 bool pushedDown; /* pushed down from higher query level? */
1643
1644/*
1645 * WithClause -
1646 * representation of WITH clause
1647 *
1648 * Note: WithClause does not propagate into the Query representation;
1649 * but CommonTableExpr does.
1650 */
1651typedef struct WithClause
1652{
1654 List *ctes; /* list of CommonTableExprs */
1655 bool recursive; /* true = WITH RECURSIVE */
1656 ParseLoc location; /* token location, or -1 if unknown */
1658
1659/*
1660 * InferClause -
1661 * ON CONFLICT unique index inference clause
1662 *
1663 * Note: InferClause does not propagate into the Query representation.
1664 */
1665typedef struct InferClause
1666{
1668 List *indexElems; /* IndexElems to infer unique index */
1669 Node *whereClause; /* qualification (partial-index predicate) */
1670 char *conname; /* Constraint name, or NULL if unnamed */
1671 ParseLoc location; /* token location, or -1 if unknown */
1673
1674/*
1675 * OnConflictClause -
1676 * representation of ON CONFLICT clause
1677 *
1678 * Note: OnConflictClause does not propagate into the Query representation.
1679 */
1680typedef struct OnConflictClause
1681{
1683 OnConflictAction action; /* DO NOTHING, SELECT, or UPDATE */
1684 InferClause *infer; /* Optional index inference clause */
1685 LockClauseStrength lockStrength; /* lock strength for DO SELECT */
1686 List *targetList; /* target list (of ResTarget) for DO UPDATE */
1687 Node *whereClause; /* qualifications */
1688 ParseLoc location; /* token location, or -1 if unknown */
1690
1691/*
1692 * CommonTableExpr -
1693 * representation of WITH list element
1694 */
1695
1696typedef enum CTEMaterialize
1697{
1698 CTEMaterializeDefault, /* no option specified */
1699 CTEMaterializeAlways, /* MATERIALIZED */
1700 CTEMaterializeNever, /* NOT MATERIALIZED */
1702
1711
1712typedef struct CTECycleClause
1713{
1721 /* These fields are set during parse analysis: */
1722 Oid cycle_mark_type; /* common type of _value and _default */
1725 Oid cycle_mark_neop; /* <> operator for type */
1727
1728typedef struct CommonTableExpr
1729{
1731
1732 /*
1733 * Query name (never qualified). The string name is included in the query
1734 * jumbling because RTE_CTE RTEs need it.
1735 */
1736 char *ctename;
1737 /* optional list of column names */
1739 CTEMaterialize ctematerialized; /* is this an optimization fence? */
1740 /* SelectStmt/InsertStmt/etc before parse analysis, Query afterwards: */
1741 Node *ctequery; /* the CTE's subquery */
1744 ParseLoc location; /* token location, or -1 if unknown */
1745 /* These fields are set during parse analysis: */
1746 /* is this CTE actually recursive? */
1748
1749 /*
1750 * Number of RTEs referencing this CTE (excluding internal
1751 * self-references), irrelevant for query jumbling.
1752 */
1754 /* list of output column names */
1756 /* OID list of output column type OIDs */
1758 /* integer list of output column typmods */
1760 /* OID list of column collation OIDs */
1763
1764/* Convenience macro to get the output tlist of a CTE's query */
1765#define GetCTETargetList(cte) \
1766 (AssertMacro(IsA((cte)->ctequery, Query)), \
1767 ((Query *) (cte)->ctequery)->commandType == CMD_SELECT ? \
1768 ((Query *) (cte)->ctequery)->targetList : \
1769 ((Query *) (cte)->ctequery)->returningList)
1770
1771/*
1772 * MergeWhenClause -
1773 * raw parser representation of a WHEN clause in a MERGE statement
1774 *
1775 * This is transformed into MergeAction by parse analysis
1776 */
1777typedef struct MergeWhenClause
1778{
1780 MergeMatchKind matchKind; /* MATCHED/NOT MATCHED BY SOURCE/TARGET */
1781 CmdType commandType; /* INSERT/UPDATE/DELETE/DO NOTHING */
1782 OverridingKind override; /* OVERRIDING clause */
1783 Node *condition; /* WHEN conditions (raw parser) */
1784 List *targetList; /* INSERT/UPDATE targetlist */
1785 /* the following members are only used in INSERT actions */
1786 List *values; /* VALUES to INSERT, or NULL */
1788
1789/*
1790 * ReturningOptionKind -
1791 * Possible kinds of option in RETURNING WITH(...) list
1792 *
1793 * Currently, this is used only for specifying OLD/NEW aliases.
1794 */
1796{
1797 RETURNING_OPTION_OLD, /* specify alias for OLD in RETURNING */
1798 RETURNING_OPTION_NEW, /* specify alias for NEW in RETURNING */
1800
1801/*
1802 * ReturningOption -
1803 * An individual option in the RETURNING WITH(...) list
1804 */
1805typedef struct ReturningOption
1806{
1808 ReturningOptionKind option; /* specified option */
1809 char *value; /* option's value */
1810 ParseLoc location; /* token location, or -1 if unknown */
1812
1813/*
1814 * ReturningClause -
1815 * List of RETURNING expressions, together with any WITH(...) options
1816 */
1817typedef struct ReturningClause
1818{
1820 List *options; /* list of ReturningOption elements */
1821 List *exprs; /* list of expressions to return */
1823
1824/*
1825 * TriggerTransition -
1826 * representation of transition row or table naming clause
1827 *
1828 * Only transition tables are initially supported in the syntax, and only for
1829 * AFTER triggers, but other permutations are accepted by the parser so we can
1830 * give a meaningful message from C code.
1831 */
1839
1840/* Nodes for SQL/JSON support */
1841
1842/*
1843 * JsonOutput -
1844 * representation of JSON output clause (RETURNING type [FORMAT format])
1845 */
1846typedef struct JsonOutput
1847{
1849 TypeName *typeName; /* RETURNING type name, if specified */
1850 JsonReturning *returning; /* RETURNING FORMAT clause and type Oids */
1852
1853/*
1854 * JsonArgument -
1855 * representation of argument from JSON PASSING clause
1856 */
1857typedef struct JsonArgument
1858{
1860 JsonValueExpr *val; /* argument value expression */
1861 char *name; /* argument name */
1863
1864/*
1865 * JsonQuotes -
1866 * representation of [KEEP|OMIT] QUOTES clause for JSON_QUERY()
1867 */
1868typedef enum JsonQuotes
1869{
1870 JS_QUOTES_UNSPEC, /* unspecified */
1871 JS_QUOTES_KEEP, /* KEEP QUOTES */
1872 JS_QUOTES_OMIT, /* OMIT QUOTES */
1874
1875/*
1876 * JsonFuncExpr -
1877 * untransformed representation of function expressions for
1878 * SQL/JSON query functions
1879 */
1880typedef struct JsonFuncExpr
1881{
1883 JsonExprOp op; /* expression type */
1884 char *column_name; /* JSON_TABLE() column name or NULL if this is
1885 * not for a JSON_TABLE() */
1886 JsonValueExpr *context_item; /* context item expression */
1887 Node *pathspec; /* JSON path specification expression */
1888 List *passing; /* list of PASSING clause arguments, if any */
1889 JsonOutput *output; /* output clause, if specified */
1890 JsonBehavior *on_empty; /* ON EMPTY behavior */
1891 JsonBehavior *on_error; /* ON ERROR behavior */
1892 JsonWrapper wrapper; /* array wrapper behavior (JSON_QUERY only) */
1893 JsonQuotes quotes; /* omit or keep quotes? (JSON_QUERY only) */
1894 ParseLoc location; /* token location, or -1 if unknown */
1896
1897/*
1898 * JsonTablePathSpec
1899 * untransformed specification of JSON path expression with an optional
1900 * name
1901 */
1911
1912/*
1913 * JsonTable -
1914 * untransformed representation of JSON_TABLE
1915 */
1916typedef struct JsonTable
1917{
1919 JsonValueExpr *context_item; /* context item expression */
1920 JsonTablePathSpec *pathspec; /* JSON path specification */
1921 List *passing; /* list of PASSING clause arguments, if any */
1922 List *columns; /* list of JsonTableColumn */
1923 JsonBehavior *on_error; /* ON ERROR behavior */
1924 Alias *alias; /* table alias in FROM clause */
1925 bool lateral; /* does it have LATERAL prefix? */
1926 ParseLoc location; /* token location, or -1 if unknown */
1928
1929/*
1930 * JsonTableColumnType -
1931 * enumeration of JSON_TABLE column types
1932 */
1941
1942/*
1943 * JsonTableColumn -
1944 * untransformed representation of JSON_TABLE column
1945 */
1946typedef struct JsonTableColumn
1947{
1949 JsonTableColumnType coltype; /* column type */
1950 char *name; /* column name */
1951 TypeName *typeName; /* column type name */
1952 JsonTablePathSpec *pathspec; /* JSON path specification */
1953 JsonFormat *format; /* JSON format clause, if specified */
1954 JsonWrapper wrapper; /* WRAPPER behavior for formatted columns */
1955 JsonQuotes quotes; /* omit or keep quotes on scalar strings? */
1956 List *columns; /* nested columns */
1957 JsonBehavior *on_empty; /* ON EMPTY behavior */
1958 JsonBehavior *on_error; /* ON ERROR behavior */
1959 ParseLoc location; /* token location, or -1 if unknown */
1961
1962/*
1963 * JsonKeyValue -
1964 * untransformed representation of JSON object key-value pair for
1965 * JSON_OBJECT() and JSON_OBJECTAGG()
1966 */
1967typedef struct JsonKeyValue
1968{
1970 Expr *key; /* key expression */
1971 JsonValueExpr *value; /* JSON value expression */
1973
1974/*
1975 * JsonParseExpr -
1976 * untransformed representation of JSON()
1977 */
1978typedef struct JsonParseExpr
1979{
1981 JsonValueExpr *expr; /* string expression */
1982 JsonOutput *output; /* RETURNING clause, if specified */
1983 bool unique_keys; /* WITH UNIQUE KEYS? */
1984 ParseLoc location; /* token location, or -1 if unknown */
1986
1987/*
1988 * JsonScalarExpr -
1989 * untransformed representation of JSON_SCALAR()
1990 */
1991typedef struct JsonScalarExpr
1992{
1994 Expr *expr; /* scalar expression */
1995 JsonOutput *output; /* RETURNING clause, if specified */
1996 ParseLoc location; /* token location, or -1 if unknown */
1998
1999/*
2000 * JsonSerializeExpr -
2001 * untransformed representation of JSON_SERIALIZE() function
2002 */
2003typedef struct JsonSerializeExpr
2004{
2006 JsonValueExpr *expr; /* json value expression */
2007 JsonOutput *output; /* RETURNING clause, if specified */
2008 ParseLoc location; /* token location, or -1 if unknown */
2010
2011/*
2012 * JsonObjectConstructor -
2013 * untransformed representation of JSON_OBJECT() constructor
2014 */
2016{
2018 List *exprs; /* list of JsonKeyValue pairs */
2019 JsonOutput *output; /* RETURNING clause, if specified */
2020 bool absent_on_null; /* skip NULL values? */
2021 bool unique; /* check key uniqueness? */
2022 ParseLoc location; /* token location, or -1 if unknown */
2024
2025/*
2026 * JsonArrayConstructor -
2027 * untransformed representation of JSON_ARRAY(element,...) constructor
2028 */
2030{
2032 List *exprs; /* list of JsonValueExpr elements */
2033 JsonOutput *output; /* RETURNING clause, if specified */
2034 bool absent_on_null; /* skip NULL elements? */
2035 ParseLoc location; /* token location, or -1 if unknown */
2037
2038/*
2039 * JsonArrayQueryConstructor -
2040 * untransformed representation of JSON_ARRAY(subquery) constructor
2041 */
2043{
2045 Node *query; /* subquery */
2046 JsonOutput *output; /* RETURNING clause, if specified */
2047 JsonFormat *format; /* FORMAT clause for subquery, if specified */
2048 bool absent_on_null; /* skip NULL elements? */
2049 ParseLoc location; /* token location, or -1 if unknown */
2051
2052/*
2053 * JsonAggConstructor -
2054 * common fields of untransformed representation of
2055 * JSON_ARRAYAGG() and JSON_OBJECTAGG()
2056 */
2058{
2060 JsonOutput *output; /* RETURNING clause, if any */
2061 Node *agg_filter; /* FILTER clause, if any */
2062 List *agg_order; /* ORDER BY clause, if any */
2063 struct WindowDef *over; /* OVER clause, if any */
2064 ParseLoc location; /* token location, or -1 if unknown */
2066
2067/*
2068 * JsonObjectAgg -
2069 * untransformed representation of JSON_OBJECTAGG()
2070 */
2071typedef struct JsonObjectAgg
2072{
2074 JsonAggConstructor *constructor; /* common fields */
2075 JsonKeyValue *arg; /* object key-value pair */
2076 bool absent_on_null; /* skip NULL values? */
2077 bool unique; /* check key uniqueness? */
2079
2080/*
2081 * JsonArrayAgg -
2082 * untransformed representation of JSON_ARRAYAGG()
2083 */
2084typedef struct JsonArrayAgg
2085{
2087 JsonAggConstructor *constructor; /* common fields */
2088 JsonValueExpr *arg; /* array element expression */
2089 bool absent_on_null; /* skip NULL elements? */
2091
2092
2093/*****************************************************************************
2094 * Raw Grammar Output Statements
2095 *****************************************************************************/
2096
2097/*
2098 * RawStmt --- container for any one statement's raw parse tree
2099 *
2100 * Parse analysis converts a raw parse tree headed by a RawStmt node into
2101 * an analyzed statement headed by a Query node. For optimizable statements,
2102 * the conversion is complex. For utility statements, the parser usually just
2103 * transfers the raw parse tree (sans RawStmt) into the utilityStmt field of
2104 * the Query node, and all the useful work happens at execution time.
2105 *
2106 * stmt_location/stmt_len identify the portion of the source text string
2107 * containing this raw statement (useful for multi-statement strings).
2108 *
2109 * This is irrelevant for query jumbling, as this is not used in parsed
2110 * queries.
2111 */
2112typedef struct RawStmt
2113{
2115
2116 NodeTag type;
2117 Node *stmt; /* raw parse tree */
2118 ParseLoc stmt_location; /* start location, or -1 if unknown */
2119 ParseLoc stmt_len; /* length in bytes; 0 means "rest of string" */
2121
2122/*****************************************************************************
2123 * Optimizable Statements
2124 *****************************************************************************/
2125
2126/* ----------------------
2127 * Insert Statement
2128 *
2129 * The source expression is represented by SelectStmt for both the
2130 * SELECT and VALUES cases. If selectStmt is NULL, then the query
2131 * is INSERT ... DEFAULT VALUES.
2132 * ----------------------
2133 */
2134typedef struct InsertStmt
2135{
2137 RangeVar *relation; /* relation to insert into */
2138 List *cols; /* optional: names of the target columns */
2139 Node *selectStmt; /* the source SELECT/VALUES, or NULL */
2140 OnConflictClause *onConflictClause; /* ON CONFLICT clause */
2141 ReturningClause *returningClause; /* RETURNING clause */
2142 WithClause *withClause; /* WITH clause */
2143 OverridingKind override; /* OVERRIDING clause */
2145
2146/* ----------------------
2147 * Delete Statement
2148 * ----------------------
2149 */
2150typedef struct DeleteStmt
2151{
2153 RangeVar *relation; /* relation to delete from */
2154 List *usingClause; /* optional using clause for more tables */
2155 Node *whereClause; /* qualifications */
2156 ReturningClause *returningClause; /* RETURNING clause */
2157 WithClause *withClause; /* WITH clause */
2159
2160/* ----------------------
2161 * Update Statement
2162 * ----------------------
2163 */
2164typedef struct UpdateStmt
2165{
2167 RangeVar *relation; /* relation to update */
2168 List *targetList; /* the target list (of ResTarget) */
2169 Node *whereClause; /* qualifications */
2170 List *fromClause; /* optional from clause for more tables */
2171 ReturningClause *returningClause; /* RETURNING clause */
2172 WithClause *withClause; /* WITH clause */
2174
2175/* ----------------------
2176 * Merge Statement
2177 * ----------------------
2178 */
2179typedef struct MergeStmt
2180{
2182 RangeVar *relation; /* target relation to merge into */
2183 Node *sourceRelation; /* source relation */
2184 Node *joinCondition; /* join condition between source and target */
2185 List *mergeWhenClauses; /* list of MergeWhenClause(es) */
2186 ReturningClause *returningClause; /* RETURNING clause */
2187 WithClause *withClause; /* WITH clause */
2189
2190/* ----------------------
2191 * Select Statement
2192 *
2193 * A "simple" SELECT is represented in the output of gram.y by a single
2194 * SelectStmt node; so is a VALUES construct. A query containing set
2195 * operators (UNION, INTERSECT, EXCEPT) is represented by a tree of SelectStmt
2196 * nodes, in which the leaf nodes are component SELECTs and the internal nodes
2197 * represent UNION, INTERSECT, or EXCEPT operators. Using the same node
2198 * type for both leaf and internal nodes allows gram.y to stick ORDER BY,
2199 * LIMIT, etc, clause values into a SELECT statement without worrying
2200 * whether it is a simple or compound SELECT.
2201 * ----------------------
2202 */
2210
2211typedef struct SelectStmt
2212{
2214
2215 /*
2216 * These fields are used only in "leaf" SelectStmts.
2217 */
2218 List *distinctClause; /* NULL, list of DISTINCT ON exprs, or
2219 * lcons(NIL,NIL) for all (SELECT DISTINCT) */
2220 IntoClause *intoClause; /* target for SELECT INTO */
2221 List *targetList; /* the target list (of ResTarget) */
2222 List *fromClause; /* the FROM clause */
2223 Node *whereClause; /* WHERE qualification */
2224 List *groupClause; /* GROUP BY clauses */
2225 bool groupDistinct; /* Is this GROUP BY DISTINCT? */
2226 bool groupByAll; /* Is this GROUP BY ALL? */
2227 Node *havingClause; /* HAVING conditional-expression */
2228 List *windowClause; /* WINDOW window_name AS (...), ... */
2229
2230 /*
2231 * In a "leaf" node representing a VALUES list, the above fields are all
2232 * null, and instead this field is set. Note that the elements of the
2233 * sublists are just expressions, without ResTarget decoration. Also note
2234 * that a list element can be DEFAULT (represented as a SetToDefault
2235 * node), regardless of the context of the VALUES list. It's up to parse
2236 * analysis to reject that where not valid.
2237 */
2238 List *valuesLists; /* untransformed list of expression lists */
2239
2240 /*
2241 * These fields are used in both "leaf" SelectStmts and upper-level
2242 * SelectStmts.
2243 */
2244 List *sortClause; /* sort clause (a list of SortBy's) */
2245 Node *limitOffset; /* # of result tuples to skip */
2246 Node *limitCount; /* # of result tuples to return */
2247 LimitOption limitOption; /* limit type */
2248 List *lockingClause; /* FOR UPDATE (list of LockingClause's) */
2249 WithClause *withClause; /* WITH clause */
2250
2251 /*
2252 * These fields are used only in upper-level SelectStmts.
2253 */
2254 SetOperation op; /* type of set op */
2255 bool all; /* ALL specified? */
2256 struct SelectStmt *larg; /* left child */
2257 struct SelectStmt *rarg; /* right child */
2258 /* Eventually add fields for CORRESPONDING spec here */
2260
2261
2262/* ----------------------
2263 * Set Operation node for post-analysis query trees
2264 *
2265 * After parse analysis, a SELECT with set operations is represented by a
2266 * top-level Query node containing the leaf SELECTs as subqueries in its
2267 * range table. Its setOperations field shows the tree of set operations,
2268 * with leaf SelectStmt nodes replaced by RangeTblRef nodes, and internal
2269 * nodes replaced by SetOperationStmt nodes. Information about the output
2270 * column types is added, too. (Note that the child nodes do not necessarily
2271 * produce these types directly, but we've checked that their output types
2272 * can be coerced to the output column type.) Also, if it's not UNION ALL,
2273 * information about the types' sort/group semantics is provided in the form
2274 * of a SortGroupClause list (same representation as, eg, DISTINCT).
2275 * The resolved common column collations are provided too; but note that if
2276 * it's not UNION ALL, it's okay for a column to not have a common collation,
2277 * so a member of the colCollations list could be InvalidOid even though the
2278 * column has a collatable type.
2279 * ----------------------
2280 */
2281typedef struct SetOperationStmt
2282{
2284 SetOperation op; /* type of set op */
2285 bool all; /* ALL specified? */
2286 Node *larg; /* left child */
2287 Node *rarg; /* right child */
2288 /* Eventually add fields for CORRESPONDING spec here */
2289
2290 /* Fields derived during parse analysis (irrelevant for query jumbling): */
2291 /* OID list of output column type OIDs */
2293 /* integer list of output column typmods */
2295 /* OID list of output column collation OIDs */
2297 /* a list of SortGroupClause's */
2299 /* groupClauses is NIL if UNION ALL, but must be set otherwise */
2301
2302
2303/*
2304 * RETURN statement (inside SQL function body)
2305 */
2311
2312
2313/* ----------------------
2314 * PL/pgSQL Assignment Statement
2315 *
2316 * Like SelectStmt, this is transformed into a SELECT Query.
2317 * However, the targetlist of the result looks more like an UPDATE.
2318 * ----------------------
2319 */
2320typedef struct PLAssignStmt
2321{
2323
2324 char *name; /* initial column name */
2325 List *indirection; /* subscripts and field names, if any */
2326 int nnames; /* number of names to use in ColumnRef */
2327 SelectStmt *val; /* the PL/pgSQL expression to assign */
2328 ParseLoc location; /* name's token location, or -1 if unknown */
2330
2331
2332/*****************************************************************************
2333 * Other Statements (no optimizations required)
2334 *
2335 * These are not touched by parser/analyze.c except to put them into
2336 * the utilityStmt field of a Query. This is eventually passed to
2337 * ProcessUtility (by-passing rewriting and planning). Some of the
2338 * statements do need attention from parse analysis, and this is
2339 * done by routines in parser/parse_utilcmd.c after ProcessUtility
2340 * receives the command for execution.
2341 * DECLARE CURSOR, EXPLAIN, and CREATE TABLE AS are special cases:
2342 * they contain optimizable statements, which get processed normally
2343 * by parser/analyze.c.
2344 *****************************************************************************/
2345
2346/*
2347 * When a command can act on several kinds of objects with only one
2348 * parse structure required, use these constants to designate the
2349 * object type. Note that commands typically don't support all the types.
2350 */
2351
2407
2408/* ----------------------
2409 * Create Schema Statement
2410 *
2411 * NOTE: the schemaElts list contains raw parsetrees for component statements
2412 * of the schema, such as CREATE TABLE, GRANT, etc. These are analyzed and
2413 * executed after the schema itself is created.
2414 * ----------------------
2415 */
2416typedef struct CreateSchemaStmt
2417{
2419 char *schemaname; /* the name of the schema to create */
2420 RoleSpec *authrole; /* the owner of the created schema */
2421 List *schemaElts; /* schema components (list of parsenodes) */
2422 bool if_not_exists; /* just do nothing if schema already exists? */
2424
2425typedef enum DropBehavior
2426{
2427 DROP_RESTRICT, /* drop fails if any dependent objects */
2428 DROP_CASCADE, /* remove dependent objects too */
2430
2431/* ----------------------
2432 * Alter Table
2433 * ----------------------
2434 */
2435typedef struct AlterTableStmt
2436{
2438 RangeVar *relation; /* table to work on */
2439 List *cmds; /* list of subcommands */
2440 ObjectType objtype; /* type of object */
2441 bool missing_ok; /* skip error if table missing */
2443
2444typedef enum AlterTableType
2445{
2446 AT_AddColumn, /* add column */
2447 AT_AddColumnToView, /* implicitly via CREATE OR REPLACE VIEW */
2448 AT_ColumnDefault, /* alter column default */
2449 AT_CookedColumnDefault, /* add a pre-cooked column default */
2450 AT_DropNotNull, /* alter column drop not null */
2451 AT_SetNotNull, /* alter column set not null */
2452 AT_SetExpression, /* alter column set expression */
2453 AT_DropExpression, /* alter column drop expression */
2454 AT_SetStatistics, /* alter column set statistics */
2455 AT_SetOptions, /* alter column set ( options ) */
2456 AT_ResetOptions, /* alter column reset ( options ) */
2457 AT_SetStorage, /* alter column set storage */
2458 AT_SetCompression, /* alter column set compression */
2459 AT_DropColumn, /* drop column */
2460 AT_AddIndex, /* add index */
2461 AT_ReAddIndex, /* internal to commands/tablecmds.c */
2462 AT_AddConstraint, /* add constraint */
2463 AT_ReAddConstraint, /* internal to commands/tablecmds.c */
2464 AT_ReAddDomainConstraint, /* internal to commands/tablecmds.c */
2465 AT_AlterConstraint, /* alter constraint */
2466 AT_ValidateConstraint, /* validate constraint */
2467 AT_AddIndexConstraint, /* add constraint using existing index */
2468 AT_DropConstraint, /* drop constraint */
2469 AT_ReAddComment, /* internal to commands/tablecmds.c */
2470 AT_AlterColumnType, /* alter column type */
2471 AT_AlterColumnGenericOptions, /* alter column OPTIONS (...) */
2472 AT_ChangeOwner, /* change owner */
2473 AT_ClusterOn, /* CLUSTER ON */
2474 AT_DropCluster, /* SET WITHOUT CLUSTER */
2475 AT_SetLogged, /* SET LOGGED */
2476 AT_SetUnLogged, /* SET UNLOGGED */
2477 AT_DropOids, /* SET WITHOUT OIDS */
2478 AT_SetAccessMethod, /* SET ACCESS METHOD */
2479 AT_SetTableSpace, /* SET TABLESPACE */
2480 AT_SetRelOptions, /* SET (...) -- AM specific parameters */
2481 AT_ResetRelOptions, /* RESET (...) -- AM specific parameters */
2482 AT_ReplaceRelOptions, /* replace reloption list in its entirety */
2483 AT_EnableTrig, /* ENABLE TRIGGER name */
2484 AT_EnableAlwaysTrig, /* ENABLE ALWAYS TRIGGER name */
2485 AT_EnableReplicaTrig, /* ENABLE REPLICA TRIGGER name */
2486 AT_DisableTrig, /* DISABLE TRIGGER name */
2487 AT_EnableTrigAll, /* ENABLE TRIGGER ALL */
2488 AT_DisableTrigAll, /* DISABLE TRIGGER ALL */
2489 AT_EnableTrigUser, /* ENABLE TRIGGER USER */
2490 AT_DisableTrigUser, /* DISABLE TRIGGER USER */
2491 AT_EnableRule, /* ENABLE RULE name */
2492 AT_EnableAlwaysRule, /* ENABLE ALWAYS RULE name */
2493 AT_EnableReplicaRule, /* ENABLE REPLICA RULE name */
2494 AT_DisableRule, /* DISABLE RULE name */
2495 AT_AddInherit, /* INHERIT parent */
2496 AT_DropInherit, /* NO INHERIT parent */
2497 AT_AddOf, /* OF <type_name> */
2498 AT_DropOf, /* NOT OF */
2499 AT_ReplicaIdentity, /* REPLICA IDENTITY */
2500 AT_EnableRowSecurity, /* ENABLE ROW SECURITY */
2501 AT_DisableRowSecurity, /* DISABLE ROW SECURITY */
2502 AT_ForceRowSecurity, /* FORCE ROW SECURITY */
2503 AT_NoForceRowSecurity, /* NO FORCE ROW SECURITY */
2504 AT_GenericOptions, /* OPTIONS (...) */
2505 AT_AttachPartition, /* ATTACH PARTITION */
2506 AT_DetachPartition, /* DETACH PARTITION */
2507 AT_DetachPartitionFinalize, /* DETACH PARTITION FINALIZE */
2508 AT_SplitPartition, /* SPLIT PARTITION */
2509 AT_MergePartitions, /* MERGE PARTITIONS */
2510 AT_AddIdentity, /* ADD IDENTITY */
2511 AT_SetIdentity, /* SET identity column options */
2512 AT_DropIdentity, /* DROP IDENTITY */
2513 AT_ReAddStatistics, /* internal to commands/tablecmds.c */
2515
2516typedef struct AlterTableCmd /* one subcommand of an ALTER TABLE */
2517{
2519 AlterTableType subtype; /* Type of table alteration to apply */
2520 char *name; /* column, constraint, or trigger to act on,
2521 * or tablespace, access method */
2522 int16 num; /* attribute number for columns referenced by
2523 * number */
2525 Node *def; /* definition of new column, index,
2526 * constraint, or parent table */
2527 DropBehavior behavior; /* RESTRICT or CASCADE for DROP cases */
2528 bool missing_ok; /* skip error if missing? */
2529 bool recurse; /* exec-time recursion */
2531
2532/* Ad-hoc node for AT_AlterConstraint */
2533typedef struct ATAlterConstraint
2534{
2536 char *conname; /* Constraint name */
2537 bool alterEnforceability; /* changing enforceability properties? */
2538 bool is_enforced; /* ENFORCED? */
2539 bool alterDeferrability; /* changing deferrability properties? */
2540 bool deferrable; /* DEFERRABLE? */
2541 bool initdeferred; /* INITIALLY DEFERRED? */
2542 bool alterInheritability; /* changing inheritability properties */
2545
2546/* Ad-hoc node for AT_ReplicaIdentity */
2553
2554
2555/* ----------------------
2556 * Alter Collation
2557 * ----------------------
2558 */
2564
2565
2566/* ----------------------
2567 * Alter Domain
2568 *
2569 * The fields are used in different ways by the different variants of
2570 * this command.
2571 * ----------------------
2572 */
2574{
2575 AD_AlterDefault = 'T', /* SET|DROP DEFAULT */
2576 AD_DropNotNull = 'N', /* DROP NOT NULL */
2577 AD_SetNotNull = 'O', /* SET NOT NULL */
2578 AD_AddConstraint = 'C', /* ADD CONSTRAINT */
2579 AD_DropConstraint = 'X', /* DROP CONSTRAINT */
2580 AD_ValidateConstraint = 'V', /* VALIDATE CONSTRAINT */
2582
2583typedef struct AlterDomainStmt
2584{
2586 AlterDomainType subtype; /* subtype of command */
2587 List *typeName; /* domain to work on */
2588 char *name; /* column or constraint name to act on */
2589 Node *def; /* definition of default or constraint */
2590 DropBehavior behavior; /* RESTRICT or CASCADE for DROP cases */
2591 bool missing_ok; /* skip error if missing? */
2593
2594
2595/* ----------------------
2596 * Grant|Revoke Statement
2597 * ----------------------
2598 */
2600{
2601 ACL_TARGET_OBJECT, /* grant on specific named object(s) */
2602 ACL_TARGET_ALL_IN_SCHEMA, /* grant on all objects in given schema(s) */
2603 ACL_TARGET_DEFAULTS, /* ALTER DEFAULT PRIVILEGES */
2605
2606typedef struct GrantStmt
2607{
2609 bool is_grant; /* true = GRANT, false = REVOKE */
2610 GrantTargetType targtype; /* type of the grant target */
2611 ObjectType objtype; /* kind of object being operated on */
2612 List *objects; /* list of RangeVar nodes, ObjectWithArgs
2613 * nodes, or plain names (as String values) */
2614 List *privileges; /* list of AccessPriv nodes */
2615 /* privileges == NIL denotes ALL PRIVILEGES */
2616 List *grantees; /* list of RoleSpec nodes */
2617 bool grant_option; /* grant or revoke grant option */
2619 DropBehavior behavior; /* drop behavior (for REVOKE) */
2621
2622/*
2623 * ObjectWithArgs represents a function/procedure/operator name plus parameter
2624 * identification.
2625 *
2626 * objargs includes only the types of the input parameters of the object.
2627 * In some contexts, that will be all we have, and it's enough to look up
2628 * objects according to the traditional Postgres rules (i.e., when only input
2629 * arguments matter).
2630 *
2631 * objfuncargs, if not NIL, carries the full specification of the parameter
2632 * list, including parameter mode annotations.
2633 *
2634 * Some grammar productions can set args_unspecified = true instead of
2635 * providing parameter info. In this case, lookup will succeed only if
2636 * the object name is unique. Note that otherwise, NIL parameter lists
2637 * mean zero arguments.
2638 */
2639typedef struct ObjectWithArgs
2640{
2642 List *objname; /* qualified name of function/operator */
2643 List *objargs; /* list of Typename nodes (input args only) */
2644 List *objfuncargs; /* list of FunctionParameter nodes */
2645 bool args_unspecified; /* argument list was omitted? */
2647
2648/*
2649 * An access privilege, with optional list of column names
2650 * priv_name == NULL denotes ALL PRIVILEGES (only used with a column list)
2651 * cols == NIL denotes "all columns"
2652 * Note that simple "ALL PRIVILEGES" is represented as a NIL list, not
2653 * an AccessPriv with both fields null.
2654 */
2655typedef struct AccessPriv
2656{
2658 char *priv_name; /* string name of privilege */
2659 List *cols; /* list of String */
2661
2662/* ----------------------
2663 * Grant/Revoke Role Statement
2664 *
2665 * Note: because of the parsing ambiguity with the GRANT <privileges>
2666 * statement, granted_roles is a list of AccessPriv; the execution code
2667 * should complain if any column lists appear. grantee_roles is a list
2668 * of role names, as String values.
2669 * ----------------------
2670 */
2671typedef struct GrantRoleStmt
2672{
2674 List *granted_roles; /* list of roles to be granted/revoked */
2675 List *grantee_roles; /* list of member roles to add/delete */
2676 bool is_grant; /* true = GRANT, false = REVOKE */
2677 List *opt; /* options e.g. WITH GRANT OPTION */
2678 RoleSpec *grantor; /* set grantor to other than current role */
2679 DropBehavior behavior; /* drop behavior (for REVOKE) */
2681
2682/* ----------------------
2683 * Alter Default Privileges Statement
2684 * ----------------------
2685 */
2687{
2689 List *options; /* list of DefElem */
2690 GrantStmt *action; /* GRANT/REVOKE action (with objects=NIL) */
2692
2693/* ----------------------
2694 * Copy Statement
2695 *
2696 * We support "COPY relation FROM file", "COPY relation TO file", and
2697 * "COPY (query) TO file". In any given CopyStmt, exactly one of "relation"
2698 * and "query" must be non-NULL.
2699 * ----------------------
2700 */
2701typedef struct CopyStmt
2702{
2704 RangeVar *relation; /* the relation to copy */
2705 Node *query; /* the query (SELECT or DML statement with
2706 * RETURNING) to copy, as a raw parse tree */
2707 List *attlist; /* List of column names (as Strings), or NIL
2708 * for all columns */
2709 bool is_from; /* TO or FROM */
2710 bool is_program; /* is 'filename' a program to popen? */
2711 char *filename; /* filename, or NULL for STDIN/STDOUT */
2712 List *options; /* List of DefElem nodes */
2713 Node *whereClause; /* WHERE condition (or NULL) */
2715
2716/* ----------------------
2717 * SET Statement (includes RESET)
2718 *
2719 * "SET var TO DEFAULT" and "RESET var" are semantically equivalent, but we
2720 * preserve the distinction in VariableSetKind for CreateCommandTag().
2721 * ----------------------
2722 */
2724{
2725 VAR_SET_VALUE, /* SET var = value */
2726 VAR_SET_DEFAULT, /* SET var TO DEFAULT */
2727 VAR_SET_CURRENT, /* SET var FROM CURRENT */
2728 VAR_SET_MULTI, /* special case for SET TRANSACTION ... */
2729 VAR_RESET, /* RESET var */
2730 VAR_RESET_ALL, /* RESET ALL */
2732
2733typedef struct VariableSetStmt
2734{
2736
2737 NodeTag type;
2739 /* variable to be set */
2740 char *name;
2741 /* List of A_Const nodes */
2743
2744 /*
2745 * True if arguments should be accounted for in query jumbling. We use a
2746 * separate flag rather than query_jumble_ignore on "args" as several
2747 * grammar flavors of SET rely on a list of values that are parsed
2748 * directly from the grammar's keywords.
2749 */
2751 /* SET LOCAL? */
2753 /* token location, or -1 if unknown */
2756
2757/* ----------------------
2758 * Show Statement
2759 * ----------------------
2760 */
2766
2767/* ----------------------
2768 * Create Table Statement
2769 *
2770 * NOTE: in the raw gram.y output, ColumnDef and Constraint nodes are
2771 * intermixed in tableElts, and constraints and nnconstraints are NIL. After
2772 * parse analysis, tableElts contains just ColumnDefs, nnconstraints contains
2773 * Constraint nodes of CONSTR_NOTNULL type from various sources, and
2774 * constraints contains just CONSTR_CHECK Constraint nodes.
2775 * ----------------------
2776 */
2777
2778typedef struct CreateStmt
2779{
2781 RangeVar *relation; /* relation to create */
2782 List *tableElts; /* column definitions (list of ColumnDef) */
2783 List *inhRelations; /* relations to inherit from (list of
2784 * RangeVar) */
2785 PartitionBoundSpec *partbound; /* FOR VALUES clause */
2786 PartitionSpec *partspec; /* PARTITION BY clause */
2787 TypeName *ofTypename; /* OF typename */
2788 List *constraints; /* constraints (list of Constraint nodes) */
2789 List *nnconstraints; /* NOT NULL constraints (ditto) */
2790 List *options; /* options from WITH clause */
2791 OnCommitAction oncommit; /* what do we do at COMMIT? */
2792 char *tablespacename; /* table space to use, or NULL */
2793 char *accessMethod; /* table access method */
2794 bool if_not_exists; /* just do nothing if it already exists? */
2796
2797/* ----------
2798 * Definitions for constraints in CreateStmt
2799 *
2800 * Note that column defaults are treated as a type of constraint,
2801 * even though that's a bit odd semantically.
2802 *
2803 * For constraints that use expressions (CONSTR_CHECK, CONSTR_DEFAULT)
2804 * we may have the expression in either "raw" form (an untransformed
2805 * parse tree) or "cooked" form (the nodeToString representation of
2806 * an executable expression tree), depending on how this Constraint
2807 * node was created (by parsing, or by inheritance from an existing
2808 * relation). We should never have both in the same node!
2809 *
2810 * FKCONSTR_ACTION_xxx values are stored into pg_constraint.confupdtype
2811 * and pg_constraint.confdeltype columns; FKCONSTR_MATCH_xxx values are
2812 * stored into pg_constraint.confmatchtype. Changing the code values may
2813 * require an initdb!
2814 *
2815 * If skip_validation is true then we skip checking that the existing rows
2816 * in the table satisfy the constraint, and just install the catalog entries
2817 * for the constraint. A new FK constraint is marked as valid iff
2818 * initially_valid is true. (Usually skip_validation and initially_valid
2819 * are inverses, but we can set both true if the table is known empty.)
2820 *
2821 * Constraint attributes (DEFERRABLE etc) are initially represented as
2822 * separate Constraint nodes for simplicity of parsing. parse_utilcmd.c makes
2823 * a pass through the constraints list to insert the info into the appropriate
2824 * Constraint node.
2825 * ----------
2826 */
2827
2848
2849/* Foreign key action codes */
2850#define FKCONSTR_ACTION_NOACTION 'a'
2851#define FKCONSTR_ACTION_RESTRICT 'r'
2852#define FKCONSTR_ACTION_CASCADE 'c'
2853#define FKCONSTR_ACTION_SETNULL 'n'
2854#define FKCONSTR_ACTION_SETDEFAULT 'd'
2855
2856/* Foreign key matchtype codes */
2857#define FKCONSTR_MATCH_FULL 'f'
2858#define FKCONSTR_MATCH_PARTIAL 'p'
2859#define FKCONSTR_MATCH_SIMPLE 's'
2860
2861typedef struct Constraint
2862{
2864 ConstrType contype; /* see above */
2865 char *conname; /* Constraint name, or NULL if unnamed */
2866 bool deferrable; /* DEFERRABLE? */
2867 bool initdeferred; /* INITIALLY DEFERRED? */
2868 bool is_enforced; /* enforced constraint? */
2869 bool skip_validation; /* skip validation of existing rows? */
2870 bool initially_valid; /* mark the new constraint as valid? */
2871 bool is_no_inherit; /* is constraint non-inheritable? */
2872 Node *raw_expr; /* CHECK or DEFAULT expression, as
2873 * untransformed parse tree */
2874 char *cooked_expr; /* CHECK or DEFAULT expression, as
2875 * nodeToString representation */
2876 char generated_when; /* ALWAYS or BY DEFAULT */
2877 char generated_kind; /* STORED or VIRTUAL */
2878 bool nulls_not_distinct; /* null treatment for UNIQUE constraints */
2879 List *keys; /* String nodes naming referenced key
2880 * column(s); for UNIQUE/PK/NOT NULL */
2881 bool without_overlaps; /* WITHOUT OVERLAPS specified */
2882 List *including; /* String nodes naming referenced nonkey
2883 * column(s); for UNIQUE/PK */
2884 List *exclusions; /* list of (IndexElem, operator name) pairs;
2885 * for exclusion constraints */
2886 List *options; /* options from WITH clause */
2887 char *indexname; /* existing index to use; otherwise NULL */
2888 char *indexspace; /* index tablespace; NULL for default */
2889 bool reset_default_tblspc; /* reset default_tablespace prior to
2890 * creating the index */
2891 char *access_method; /* index access method; NULL for default */
2892 Node *where_clause; /* partial index predicate */
2893
2894 /* Fields used for FOREIGN KEY constraints: */
2895 RangeVar *pktable; /* Primary key table */
2896 List *fk_attrs; /* Attributes of foreign key */
2897 List *pk_attrs; /* Corresponding attrs in PK table */
2898 bool fk_with_period; /* Last attribute of FK uses PERIOD */
2899 bool pk_with_period; /* Last attribute of PK uses PERIOD */
2900 char fk_matchtype; /* FULL, PARTIAL, SIMPLE */
2901 char fk_upd_action; /* ON UPDATE action */
2902 char fk_del_action; /* ON DELETE action */
2903 List *fk_del_set_cols; /* ON DELETE SET NULL/DEFAULT (col1, col2) */
2904 List *old_conpfeqop; /* pg_constraint.conpfeqop of my former self */
2905 Oid old_pktable_oid; /* pg_constraint.confrelid of my former
2906 * self */
2907
2908 ParseLoc location; /* token location, or -1 if unknown */
2910
2911/* ----------------------
2912 * Create/Drop Table Space Statements
2913 * ----------------------
2914 */
2915
2924
2926{
2929 bool missing_ok; /* skip error if missing? */
2931
2939
2941{
2944 ObjectType objtype; /* Object type to move */
2945 List *roles; /* List of roles to move objects of */
2949
2950/* ----------------------
2951 * Create/Alter Extension Statements
2952 * ----------------------
2953 */
2954
2956{
2958 char *extname;
2959 bool if_not_exists; /* just do nothing if it already exists? */
2960 List *options; /* List of DefElem nodes */
2962
2963/* Only used for ALTER EXTENSION UPDATE; later might need an action field */
2965{
2967 char *extname;
2968 List *options; /* List of DefElem nodes */
2970
2972{
2974 char *extname; /* Extension's name */
2975 int action; /* +1 = add object, -1 = drop object */
2976 ObjectType objtype; /* Object's type */
2977 Node *object; /* Qualified name of the object */
2979
2980/* ----------------------
2981 * Create/Alter FOREIGN DATA WRAPPER Statements
2982 * ----------------------
2983 */
2984
2985typedef struct CreateFdwStmt
2986{
2988 char *fdwname; /* foreign-data wrapper name */
2989 List *func_options; /* HANDLER/VALIDATOR options */
2990 List *options; /* generic options to FDW */
2992
2993typedef struct AlterFdwStmt
2994{
2996 char *fdwname; /* foreign-data wrapper name */
2997 List *func_options; /* HANDLER/VALIDATOR options */
2998 List *options; /* generic options to FDW */
3000
3001/* ----------------------
3002 * Create/Alter FOREIGN SERVER Statements
3003 * ----------------------
3004 */
3005
3007{
3009 char *servername; /* server name */
3010 char *servertype; /* optional server type */
3011 char *version; /* optional server version */
3012 char *fdwname; /* FDW name */
3013 bool if_not_exists; /* just do nothing if it already exists? */
3014 List *options; /* generic options to server */
3016
3018{
3020 char *servername; /* server name */
3021 char *version; /* optional server version */
3022 List *options; /* generic options to server */
3023 bool has_version; /* version specified */
3025
3026/* ----------------------
3027 * Create FOREIGN TABLE Statement
3028 * ----------------------
3029 */
3030
3037
3038/* ----------------------
3039 * Create/Drop USER MAPPING Statements
3040 * ----------------------
3041 */
3042
3044{
3046 RoleSpec *user; /* user role */
3047 char *servername; /* server name */
3048 bool if_not_exists; /* just do nothing if it already exists? */
3049 List *options; /* generic options to server */
3051
3053{
3055 RoleSpec *user; /* user role */
3056 char *servername; /* server name */
3057 List *options; /* generic options to server */
3059
3061{
3063 RoleSpec *user; /* user role */
3064 char *servername; /* server name */
3065 bool missing_ok; /* ignore missing mappings */
3067
3068/* ----------------------
3069 * Import Foreign Schema Statement
3070 * ----------------------
3071 */
3072
3074{
3075 FDW_IMPORT_SCHEMA_ALL, /* all relations wanted */
3076 FDW_IMPORT_SCHEMA_LIMIT_TO, /* include only listed tables in import */
3077 FDW_IMPORT_SCHEMA_EXCEPT, /* exclude listed tables from import */
3079
3081{
3083 char *server_name; /* FDW server name */
3084 char *remote_schema; /* remote schema name to query */
3085 char *local_schema; /* local schema to create objects in */
3086 ImportForeignSchemaType list_type; /* type of table list */
3087 List *table_list; /* List of RangeVar */
3088 List *options; /* list of options to pass to FDW */
3090
3091/*----------------------
3092 * Create POLICY Statement
3093 *----------------------
3094 */
3095typedef struct CreatePolicyStmt
3096{
3098 char *policy_name; /* Policy's name */
3099 RangeVar *table; /* the table name the policy applies to */
3100 char *cmd_name; /* the command name the policy applies to */
3101 bool permissive; /* restrictive or permissive policy */
3102 List *roles; /* the roles associated with the policy */
3103 Node *qual; /* the policy's condition */
3104 Node *with_check; /* the policy's WITH CHECK condition. */
3106
3107/*----------------------
3108 * Alter POLICY Statement
3109 *----------------------
3110 */
3111typedef struct AlterPolicyStmt
3112{
3114 char *policy_name; /* Policy's name */
3115 RangeVar *table; /* the table name the policy applies to */
3116 List *roles; /* the roles associated with the policy */
3117 Node *qual; /* the policy's condition */
3118 Node *with_check; /* the policy's WITH CHECK condition. */
3120
3121/*----------------------
3122 * Create ACCESS METHOD Statement
3123 *----------------------
3124 */
3125typedef struct CreateAmStmt
3126{
3128 char *amname; /* access method name */
3129 List *handler_name; /* handler function name */
3130 char amtype; /* type of access method */
3132
3133/* ----------------------
3134 * Create TRIGGER Statement
3135 * ----------------------
3136 */
3137typedef struct CreateTrigStmt
3138{
3140 bool replace; /* replace trigger if already exists */
3141 bool isconstraint; /* This is a constraint trigger */
3142 char *trigname; /* TRIGGER's name */
3143 RangeVar *relation; /* relation trigger is on */
3144 List *funcname; /* qual. name of function to call */
3145 List *args; /* list of String or NIL */
3146 bool row; /* ROW/STATEMENT */
3147 /* timing uses the TRIGGER_TYPE bits defined in catalog/pg_trigger.h */
3148 int16 timing; /* BEFORE, AFTER, or INSTEAD */
3149 /* events uses the TRIGGER_TYPE bits defined in catalog/pg_trigger.h */
3150 int16 events; /* "OR" of INSERT/UPDATE/DELETE/TRUNCATE */
3151 List *columns; /* column names, or NIL for all columns */
3152 Node *whenClause; /* qual expression, or NULL if none */
3153 /* explicitly named transition data */
3154 List *transitionRels; /* TriggerTransition nodes, or NIL if none */
3155 /* The remaining fields are only used for constraint triggers */
3156 bool deferrable; /* [NOT] DEFERRABLE */
3157 bool initdeferred; /* INITIALLY {DEFERRED|IMMEDIATE} */
3158 RangeVar *constrrel; /* opposite relation, if RI trigger */
3160
3161/* ----------------------
3162 * Create EVENT TRIGGER Statement
3163 * ----------------------
3164 */
3166{
3168 char *trigname; /* TRIGGER's name */
3169 char *eventname; /* event's identifier */
3170 List *whenclause; /* list of DefElems indicating filtering */
3171 List *funcname; /* qual. name of function to call */
3173
3174/* ----------------------
3175 * Alter EVENT TRIGGER Statement
3176 * ----------------------
3177 */
3179{
3181 char *trigname; /* TRIGGER's name */
3182 char tgenabled; /* trigger's firing configuration WRT
3183 * session_replication_role */
3185
3186/* ----------------------
3187 * Create LANGUAGE Statements
3188 * ----------------------
3189 */
3190typedef struct CreatePLangStmt
3191{
3193 bool replace; /* T => replace if already exists */
3194 char *plname; /* PL name */
3195 List *plhandler; /* PL call handler function (qual. name) */
3196 List *plinline; /* optional inline function (qual. name) */
3197 List *plvalidator; /* optional validator function (qual. name) */
3198 bool pltrusted; /* PL is trusted */
3200
3201/* ----------------------
3202 * Create/Alter/Drop Role Statements
3203 *
3204 * Note: these node types are also used for the backwards-compatible
3205 * Create/Alter/Drop User/Group statements. In the ALTER and DROP cases
3206 * there's really no need to distinguish what the original spelling was,
3207 * but for CREATE we mark the type because the defaults vary.
3208 * ----------------------
3209 */
3216
3217typedef struct CreateRoleStmt
3218{
3220 RoleStmtType stmt_type; /* ROLE/USER/GROUP */
3221 char *role; /* role name */
3222 List *options; /* List of DefElem nodes */
3224
3225typedef struct AlterRoleStmt
3226{
3228 RoleSpec *role; /* role */
3229 List *options; /* List of DefElem nodes */
3230 int action; /* +1 = add members, -1 = drop members */
3232
3233typedef struct AlterRoleSetStmt
3234{
3236 RoleSpec *role; /* role */
3237 char *database; /* database name, or NULL */
3238 VariableSetStmt *setstmt; /* SET or RESET subcommand */
3240
3241typedef struct DropRoleStmt
3242{
3244 List *roles; /* List of roles to remove */
3245 bool missing_ok; /* skip error if a role is missing? */
3247
3248/* ----------------------
3249 * {Create|Alter} SEQUENCE Statement
3250 * ----------------------
3251 */
3252
3253typedef struct CreateSeqStmt
3254{
3256 RangeVar *sequence; /* the sequence to create */
3258 Oid ownerId; /* ID of owner, or InvalidOid for default */
3260 bool if_not_exists; /* just do nothing if it already exists? */
3262
3263typedef struct AlterSeqStmt
3264{
3266 RangeVar *sequence; /* the sequence to alter */
3269 bool missing_ok; /* skip error if a role is missing? */
3271
3272/* ----------------------
3273 * Create {Aggregate|Operator|Type} Statement
3274 * ----------------------
3275 */
3276typedef struct DefineStmt
3277{
3279 ObjectType kind; /* aggregate, operator, type */
3280 bool oldstyle; /* hack to signal old CREATE AGG syntax */
3281 List *defnames; /* qualified name (list of String) */
3282 List *args; /* a list of TypeName (if needed) */
3283 List *definition; /* a list of DefElem */
3284 bool if_not_exists; /* just do nothing if it already exists? */
3285 bool replace; /* replace if already exists? */
3287
3288/* ----------------------
3289 * Create Domain Statement
3290 * ----------------------
3291 */
3292typedef struct CreateDomainStmt
3293{
3295 List *domainname; /* qualified name (list of String) */
3296 TypeName *typeName; /* the base type */
3297 CollateClause *collClause; /* untransformed COLLATE spec, if any */
3298 List *constraints; /* constraints (list of Constraint nodes) */
3300
3301/* ----------------------
3302 * Create Operator Class Statement
3303 * ----------------------
3304 */
3305typedef struct CreateOpClassStmt
3306{
3308 List *opclassname; /* qualified name (list of String) */
3309 List *opfamilyname; /* qualified name (ditto); NIL if omitted */
3310 char *amname; /* name of index AM opclass is for */
3311 TypeName *datatype; /* datatype of indexed column */
3312 List *items; /* List of CreateOpClassItem nodes */
3313 bool isDefault; /* Should be marked as default for type? */
3315
3316#define OPCLASS_ITEM_OPERATOR 1
3317#define OPCLASS_ITEM_FUNCTION 2
3318#define OPCLASS_ITEM_STORAGETYPE 3
3319
3320typedef struct CreateOpClassItem
3321{
3323 int itemtype; /* see codes above */
3324 ObjectWithArgs *name; /* operator or function name and args */
3325 int number; /* strategy num or support proc num */
3326 List *order_family; /* only used for ordering operators */
3327 List *class_args; /* amproclefttype/amprocrighttype or
3328 * amoplefttype/amoprighttype */
3329 /* fields used for a storagetype item: */
3330 TypeName *storedtype; /* datatype stored in index */
3332
3333/* ----------------------
3334 * Create Operator Family Statement
3335 * ----------------------
3336 */
3338{
3340 List *opfamilyname; /* qualified name (list of String) */
3341 char *amname; /* name of index AM opfamily is for */
3343
3344/* ----------------------
3345 * Alter Operator Family Statement
3346 * ----------------------
3347 */
3348typedef struct AlterOpFamilyStmt
3349{
3351 List *opfamilyname; /* qualified name (list of String) */
3352 char *amname; /* name of index AM opfamily is for */
3353 bool isDrop; /* ADD or DROP the items? */
3354 List *items; /* List of CreateOpClassItem nodes */
3356
3357/* ----------------------
3358 * Drop Table|Sequence|View|Index|Type|Domain|Conversion|Schema Statement
3359 * ----------------------
3360 */
3361
3362typedef struct DropStmt
3363{
3365 List *objects; /* list of names */
3366 ObjectType removeType; /* object type */
3367 DropBehavior behavior; /* RESTRICT or CASCADE behavior */
3368 bool missing_ok; /* skip error if object is missing? */
3369 bool concurrent; /* drop index concurrently? */
3371
3372/* ----------------------
3373 * Truncate Table Statement
3374 * ----------------------
3375 */
3376typedef struct TruncateStmt
3377{
3379 List *relations; /* relations (RangeVars) to be truncated */
3380 bool restart_seqs; /* restart owned sequences? */
3381 DropBehavior behavior; /* RESTRICT or CASCADE behavior */
3383
3384/* ----------------------
3385 * Comment On Statement
3386 * ----------------------
3387 */
3388typedef struct CommentStmt
3389{
3391 ObjectType objtype; /* Object's type */
3392 Node *object; /* Qualified name of the object */
3393 char *comment; /* Comment to insert, or NULL to remove */
3395
3396/* ----------------------
3397 * SECURITY LABEL Statement
3398 * ----------------------
3399 */
3400typedef struct SecLabelStmt
3401{
3403 ObjectType objtype; /* Object's type */
3404 Node *object; /* Qualified name of the object */
3405 char *provider; /* Label provider (or NULL) */
3406 char *label; /* New security label to be assigned */
3408
3409/* ----------------------
3410 * Declare Cursor Statement
3411 *
3412 * The "query" field is initially a raw parse tree, and is converted to a
3413 * Query node during parse analysis. Note that rewriting and planning
3414 * of the query are always postponed until execution.
3415 * ----------------------
3416 */
3417#define CURSOR_OPT_BINARY 0x0001 /* BINARY */
3418#define CURSOR_OPT_SCROLL 0x0002 /* SCROLL explicitly given */
3419#define CURSOR_OPT_NO_SCROLL 0x0004 /* NO SCROLL explicitly given */
3420#define CURSOR_OPT_INSENSITIVE 0x0008 /* INSENSITIVE */
3421#define CURSOR_OPT_ASENSITIVE 0x0010 /* ASENSITIVE */
3422#define CURSOR_OPT_HOLD 0x0020 /* WITH HOLD */
3423/* these planner-control flags do not correspond to any SQL grammar: */
3424#define CURSOR_OPT_FAST_PLAN 0x0100 /* prefer fast-start plan */
3425#define CURSOR_OPT_GENERIC_PLAN 0x0200 /* force use of generic plan */
3426#define CURSOR_OPT_CUSTOM_PLAN 0x0400 /* force use of custom plan */
3427#define CURSOR_OPT_PARALLEL_OK 0x0800 /* parallel mode OK */
3428
3429typedef struct DeclareCursorStmt
3430{
3432 char *portalname; /* name of the portal (cursor) */
3433 int options; /* bitmask of options (see above) */
3434 Node *query; /* the query (see comments above) */
3436
3437/* ----------------------
3438 * Close Portal Statement
3439 * ----------------------
3440 */
3441typedef struct ClosePortalStmt
3442{
3444 char *portalname; /* name of the portal (cursor) */
3445 /* NULL means CLOSE ALL */
3447
3448/* ----------------------
3449 * Fetch Statement (also Move)
3450 * ----------------------
3451 */
3452typedef enum FetchDirection
3453{
3454 /* for these, howMany is how many rows to fetch; FETCH_ALL means ALL */
3457 /* for these, howMany indicates a position; only one row is fetched */
3461
3477
3478#define FETCH_ALL LONG_MAX
3479
3480typedef struct FetchStmt
3481{
3483 FetchDirection direction; /* see above */
3484 /* number of rows, or position argument */
3486 /* name of portal (cursor) */
3488 /* true if MOVE */
3490
3491 /*
3492 * Set when a direction_keyword (e.g., FETCH FORWARD) is used, to
3493 * distinguish it from a numeric variant (e.g., FETCH 1) for the purpose
3494 * of query jumbling.
3495 */
3497
3498 /* token location, or -1 if unknown */
3501
3502/* ----------------------
3503 * Create Index Statement
3504 *
3505 * This represents creation of an index and/or an associated constraint.
3506 * If isconstraint is true, we should create a pg_constraint entry along
3507 * with the index. But if indexOid isn't InvalidOid, we are not creating an
3508 * index, just a UNIQUE/PKEY constraint using an existing index. isconstraint
3509 * must always be true in this case, and the fields describing the index
3510 * properties are empty.
3511 * ----------------------
3512 */
3513typedef struct IndexStmt
3514{
3516 char *idxname; /* name of new index, or NULL for default */
3517 RangeVar *relation; /* relation to build index on */
3518 char *accessMethod; /* name of access method (eg. btree) */
3519 char *tableSpace; /* tablespace, or NULL for default */
3520 List *indexParams; /* columns to index: a list of IndexElem */
3521 List *indexIncludingParams; /* additional columns to index: a list
3522 * of IndexElem */
3523 List *options; /* WITH clause options: a list of DefElem */
3524 Node *whereClause; /* qualification (partial-index predicate) */
3525 List *excludeOpNames; /* exclusion operator names, or NIL if none */
3526 char *idxcomment; /* comment to apply to index, or NULL */
3527 Oid indexOid; /* OID of an existing index, if any */
3528 RelFileNumber oldNumber; /* relfilenumber of existing storage, if any */
3529 SubTransactionId oldCreateSubid; /* rd_createSubid of oldNumber */
3530 SubTransactionId oldFirstRelfilelocatorSubid; /* rd_firstRelfilelocatorSubid
3531 * of oldNumber */
3532 bool unique; /* is index unique? */
3533 bool nulls_not_distinct; /* null treatment for UNIQUE constraints */
3534 bool primary; /* is index a primary key? */
3535 bool isconstraint; /* is it for a pkey/unique constraint? */
3536 bool iswithoutoverlaps; /* is the constraint WITHOUT OVERLAPS? */
3537 bool deferrable; /* is the constraint DEFERRABLE? */
3538 bool initdeferred; /* is the constraint INITIALLY DEFERRED? */
3539 bool transformed; /* true when transformIndexStmt is finished */
3540 bool concurrent; /* should this be a concurrent index build? */
3541 bool if_not_exists; /* just do nothing if index already exists? */
3542 bool reset_default_tblspc; /* reset default_tablespace prior to
3543 * executing */
3545
3546/* ----------------------
3547 * Create Statistics Statement
3548 * ----------------------
3549 */
3550typedef struct CreateStatsStmt
3551{
3553 List *defnames; /* qualified name (list of String) */
3554 List *stat_types; /* stat types (list of String) */
3555 List *exprs; /* expressions to build statistics on */
3556 List *relations; /* rels to build stats on (list of RangeVar) */
3557 char *stxcomment; /* comment to apply to stats, or NULL */
3558 bool transformed; /* true when transformStatsStmt is finished */
3559 bool if_not_exists; /* do nothing if stats name already exists */
3561
3562/*
3563 * StatsElem - statistics parameters (used in CREATE STATISTICS)
3564 *
3565 * For a plain attribute, 'name' is the name of the referenced table column
3566 * and 'expr' is NULL. For an expression, 'name' is NULL and 'expr' is the
3567 * expression tree.
3568 */
3569typedef struct StatsElem
3570{
3572 char *name; /* name of attribute to index, or NULL */
3573 Node *expr; /* expression to index, or NULL */
3575
3576
3577/* ----------------------
3578 * Alter Statistics Statement
3579 * ----------------------
3580 */
3581typedef struct AlterStatsStmt
3582{
3584 List *defnames; /* qualified name (list of String) */
3585 Node *stxstattarget; /* statistics target */
3586 bool missing_ok; /* skip error if statistics object is missing */
3588
3589/* ----------------------
3590 * Create Function Statement
3591 * ----------------------
3592 */
3594{
3596 bool is_procedure; /* it's really CREATE PROCEDURE */
3597 bool replace; /* T => replace if already exists */
3598 List *funcname; /* qualified name of function to create */
3599 List *parameters; /* a list of FunctionParameter */
3600 TypeName *returnType; /* the return type */
3601 List *options; /* a list of DefElem */
3604
3606{
3607 /* the assigned enum values appear in pg_proc, don't change 'em! */
3608 FUNC_PARAM_IN = 'i', /* input only */
3609 FUNC_PARAM_OUT = 'o', /* output only */
3610 FUNC_PARAM_INOUT = 'b', /* both */
3611 FUNC_PARAM_VARIADIC = 'v', /* variadic (always input) */
3612 FUNC_PARAM_TABLE = 't', /* table function output column */
3613 /* this is not used in pg_proc: */
3614 FUNC_PARAM_DEFAULT = 'd', /* default; effectively same as IN */
3616
3617typedef struct FunctionParameter
3618{
3620 char *name; /* parameter name, or NULL if not given */
3621 TypeName *argType; /* TypeName for parameter type */
3622 FunctionParameterMode mode; /* IN/OUT/etc */
3623 Node *defexpr; /* raw default expr, or NULL if not given */
3624 ParseLoc location; /* token location, or -1 if unknown */
3626
3627typedef struct AlterFunctionStmt
3628{
3631 ObjectWithArgs *func; /* name and args of function */
3632 List *actions; /* list of DefElem */
3634
3635/* ----------------------
3636 * DO Statement
3637 *
3638 * DoStmt is the raw parser output, InlineCodeBlock is the execution-time API
3639 * ----------------------
3640 */
3641typedef struct DoStmt
3642{
3644 List *args; /* List of DefElem nodes */
3646
3647typedef struct InlineCodeBlock
3648{
3649 pg_node_attr(nodetag_only) /* this is not a member of parse trees */
3650
3651 NodeTag type;
3652 char *source_text; /* source text of anonymous code block */
3653 Oid langOid; /* OID of selected language */
3654 bool langIsTrusted; /* trusted property of the language */
3655 bool atomic; /* atomic execution context */
3657
3658/* ----------------------
3659 * CALL statement
3660 *
3661 * OUT-mode arguments are removed from the transformed funcexpr. The outargs
3662 * list contains copies of the expressions for all output arguments, in the
3663 * order of the procedure's declared arguments. (outargs is never evaluated,
3664 * but is useful to the caller as a reference for what to assign to.)
3665 * The transformed call state is not relevant in the query jumbling, only the
3666 * function call is.
3667 * ----------------------
3668 */
3669typedef struct CallStmt
3670{
3672 /* from the parser */
3674 /* transformed call, with only input args */
3676 /* transformed output-argument expressions */
3679
3680typedef struct CallContext
3681{
3682 pg_node_attr(nodetag_only) /* this is not a member of parse trees */
3683
3684 NodeTag type;
3687
3688/* ----------------------
3689 * Alter Object Rename Statement
3690 * ----------------------
3691 */
3692typedef struct RenameStmt
3693{
3695 ObjectType renameType; /* OBJECT_TABLE, OBJECT_COLUMN, etc */
3696 ObjectType relationType; /* if column name, associated relation type */
3697 RangeVar *relation; /* in case it's a table */
3698 Node *object; /* in case it's some other object */
3699 char *subname; /* name of contained object (column, rule,
3700 * trigger, etc) */
3701 char *newname; /* the new name */
3702 DropBehavior behavior; /* RESTRICT or CASCADE behavior */
3703 bool missing_ok; /* skip error if missing? */
3705
3706/* ----------------------
3707 * ALTER object DEPENDS ON EXTENSION extname
3708 * ----------------------
3709 */
3711{
3713 ObjectType objectType; /* OBJECT_FUNCTION, OBJECT_TRIGGER, etc */
3714 RangeVar *relation; /* in case a table is involved */
3715 Node *object; /* name of the object */
3716 String *extname; /* extension name */
3717 bool remove; /* set true to remove dep rather than add */
3719
3720/* ----------------------
3721 * ALTER object SET SCHEMA Statement
3722 * ----------------------
3723 */
3725{
3727 ObjectType objectType; /* OBJECT_TABLE, OBJECT_TYPE, etc */
3728 RangeVar *relation; /* in case it's a table */
3729 Node *object; /* in case it's some other object */
3730 char *newschema; /* the new schema */
3731 bool missing_ok; /* skip error if missing? */
3733
3734/* ----------------------
3735 * Alter Object Owner Statement
3736 * ----------------------
3737 */
3738typedef struct AlterOwnerStmt
3739{
3741 ObjectType objectType; /* OBJECT_TABLE, OBJECT_TYPE, etc */
3742 RangeVar *relation; /* in case it's a table */
3743 Node *object; /* in case it's some other object */
3744 RoleSpec *newowner; /* the new owner */
3746
3747/* ----------------------
3748 * Alter Operator Set ( this-n-that )
3749 * ----------------------
3750 */
3751typedef struct AlterOperatorStmt
3752{
3754 ObjectWithArgs *opername; /* operator name and argument types */
3755 List *options; /* List of DefElem nodes */
3757
3758/* ------------------------
3759 * Alter Type Set ( this-n-that )
3760 * ------------------------
3761 */
3762typedef struct AlterTypeStmt
3763{
3765 List *typeName; /* type name (possibly qualified) */
3766 List *options; /* List of DefElem nodes */
3768
3769/* ----------------------
3770 * Create Rule Statement
3771 * ----------------------
3772 */
3773typedef struct RuleStmt
3774{
3776 RangeVar *relation; /* relation the rule is for */
3777 char *rulename; /* name of the rule */
3778 Node *whereClause; /* qualifications */
3779 CmdType event; /* SELECT, INSERT, etc */
3780 bool instead; /* is a 'do instead'? */
3781 List *actions; /* the action statements */
3782 bool replace; /* OR REPLACE */
3784
3785/* ----------------------
3786 * Notify Statement
3787 * ----------------------
3788 */
3789typedef struct NotifyStmt
3790{
3792 char *conditionname; /* condition name to notify */
3793 char *payload; /* the payload string, or NULL if none */
3795
3796/* ----------------------
3797 * Listen Statement
3798 * ----------------------
3799 */
3800typedef struct ListenStmt
3801{
3803 char *conditionname; /* condition name to listen on */
3805
3806/* ----------------------
3807 * Unlisten Statement
3808 * ----------------------
3809 */
3810typedef struct UnlistenStmt
3811{
3813 char *conditionname; /* name to unlisten on, or NULL for all */
3815
3816/* ----------------------
3817 * {Begin|Commit|Rollback} Transaction Statement
3818 * ----------------------
3819 */
3833
3834typedef struct TransactionStmt
3835{
3837 TransactionStmtKind kind; /* see above */
3838 List *options; /* for BEGIN/START commands */
3839 /* for savepoint commands */
3841 /* for two-phase-commit related commands */
3843 bool chain; /* AND CHAIN option */
3844 /* token location, or -1 if unknown */
3847
3848/* ----------------------
3849 * Create Type Statement, composite types
3850 * ----------------------
3851 */
3852typedef struct CompositeTypeStmt
3853{
3855 RangeVar *typevar; /* the composite type to be created */
3856 List *coldeflist; /* list of ColumnDef nodes */
3858
3859/* ----------------------
3860 * Create Type Statement, enum types
3861 * ----------------------
3862 */
3863typedef struct CreateEnumStmt
3864{
3866 List *typeName; /* qualified name (list of String) */
3867 List *vals; /* enum values (list of String) */
3869
3870/* ----------------------
3871 * Create Type Statement, range types
3872 * ----------------------
3873 */
3874typedef struct CreateRangeStmt
3875{
3877 List *typeName; /* qualified name (list of String) */
3878 List *params; /* range parameters (list of DefElem) */
3880
3881/* ----------------------
3882 * Alter Type Statement, enum types
3883 * ----------------------
3884 */
3885typedef struct AlterEnumStmt
3886{
3888 List *typeName; /* qualified name (list of String) */
3889 char *oldVal; /* old enum value's name, if renaming */
3890 char *newVal; /* new enum value's name */
3891 char *newValNeighbor; /* neighboring enum value, if specified */
3892 bool newValIsAfter; /* place new enum value after neighbor? */
3893 bool skipIfNewValExists; /* no error if new already exists? */
3895
3896/* ----------------------
3897 * Create View Statement
3898 * ----------------------
3899 */
3906
3907typedef struct ViewStmt
3908{
3910 RangeVar *view; /* the view to be created */
3911 List *aliases; /* target column names */
3912 Node *query; /* the SELECT query (as a raw parse tree) */
3913 bool replace; /* replace an existing view? */
3914 List *options; /* options from WITH clause */
3915 ViewCheckOption withCheckOption; /* WITH CHECK OPTION */
3917
3918/* ----------------------
3919 * Load Statement
3920 * ----------------------
3921 */
3922typedef struct LoadStmt
3923{
3925 char *filename; /* file to load */
3927
3928/* ----------------------
3929 * Createdb Statement
3930 * ----------------------
3931 */
3932typedef struct CreatedbStmt
3933{
3935 char *dbname; /* name of database to create */
3936 List *options; /* List of DefElem nodes */
3938
3939/* ----------------------
3940 * Alter Database
3941 * ----------------------
3942 */
3943typedef struct AlterDatabaseStmt
3944{
3946 char *dbname; /* name of database to alter */
3947 List *options; /* List of DefElem nodes */
3949
3955
3957{
3959 char *dbname; /* database name */
3960 VariableSetStmt *setstmt; /* SET or RESET subcommand */
3962
3963/* ----------------------
3964 * Dropdb Statement
3965 * ----------------------
3966 */
3967typedef struct DropdbStmt
3968{
3970 char *dbname; /* database to drop */
3971 bool missing_ok; /* skip error if db is missing? */
3972 List *options; /* currently only FORCE is supported */
3974
3975/* ----------------------
3976 * Alter System Statement
3977 * ----------------------
3978 */
3984
3985/* ----------------------
3986 * Cluster Statement (support pbrown's cluster index implementation)
3987 * ----------------------
3988 */
3989typedef struct ClusterStmt
3990{
3992 RangeVar *relation; /* relation being indexed, or NULL if all */
3993 char *indexname; /* original index defined */
3994 List *params; /* list of DefElem nodes */
3996
3997/* ----------------------
3998 * Vacuum and Analyze Statements
3999 *
4000 * Even though these are nominally two statements, it's convenient to use
4001 * just one node type for both.
4002 * ----------------------
4003 */
4004typedef struct VacuumStmt
4005{
4007 List *options; /* list of DefElem nodes */
4008 List *rels; /* list of VacuumRelation, or NIL for all */
4009 bool is_vacuumcmd; /* true for VACUUM, false for ANALYZE */
4011
4012/*
4013 * Info about a single target table of VACUUM/ANALYZE.
4014 *
4015 * If the OID field is set, it always identifies the table to process.
4016 * Then the relation field can be NULL; if it isn't, it's used only to report
4017 * failure to open/lock the relation.
4018 */
4019typedef struct VacuumRelation
4020{
4022 RangeVar *relation; /* table name to process, or NULL */
4023 Oid oid; /* table's OID; InvalidOid if not looked up */
4024 List *va_cols; /* list of column names, or NIL for all */
4026
4027/* ----------------------
4028 * Explain Statement
4029 *
4030 * The "query" field is initially a raw parse tree, and is converted to a
4031 * Query node during parse analysis. Note that rewriting and planning
4032 * of the query are always postponed until execution.
4033 * ----------------------
4034 */
4035typedef struct ExplainStmt
4036{
4038 Node *query; /* the query (see comments above) */
4039 List *options; /* list of DefElem nodes */
4041
4042/* ----------------------
4043 * CREATE TABLE AS Statement (a/k/a SELECT INTO)
4044 *
4045 * A query written as CREATE TABLE AS will produce this node type natively.
4046 * A query written as SELECT ... INTO will be transformed to this form during
4047 * parse analysis.
4048 * A query written as CREATE MATERIALIZED view will produce this node type,
4049 * during parse analysis, since it needs all the same data.
4050 *
4051 * The "query" field is handled similarly to EXPLAIN, though note that it
4052 * can be a SELECT or an EXECUTE, but not other DML statements.
4053 * ----------------------
4054 */
4055typedef struct CreateTableAsStmt
4056{
4058 Node *query; /* the query (see comments above) */
4059 IntoClause *into; /* destination table */
4060 ObjectType objtype; /* OBJECT_TABLE or OBJECT_MATVIEW */
4061 bool is_select_into; /* it was written as SELECT INTO */
4062 bool if_not_exists; /* just do nothing if it already exists? */
4064
4065/* ----------------------
4066 * REFRESH MATERIALIZED VIEW Statement
4067 * ----------------------
4068 */
4070{
4072 bool concurrent; /* allow concurrent access? */
4073 bool skipData; /* true for WITH NO DATA */
4074 RangeVar *relation; /* relation to insert into */
4076
4077/* ----------------------
4078 * Checkpoint Statement
4079 * ----------------------
4080 */
4081typedef struct CheckPointStmt
4082{
4084 List *options; /* list of DefElem nodes */
4086
4087/* ----------------------
4088 * Discard Statement
4089 * ----------------------
4090 */
4091
4099
4105
4106/* ----------------------
4107 * LOCK Statement
4108 * ----------------------
4109 */
4110typedef struct LockStmt
4111{
4113 List *relations; /* relations to lock */
4114 int mode; /* lock mode */
4115 bool nowait; /* no wait mode */
4117
4118/* ----------------------
4119 * SET CONSTRAINTS Statement
4120 * ----------------------
4121 */
4123{
4125 List *constraints; /* List of names as RangeVars */
4128
4129/* ----------------------
4130 * REINDEX Statement
4131 * ----------------------
4132 */
4134{
4136 REINDEX_OBJECT_TABLE, /* table or materialized view */
4138 REINDEX_OBJECT_SYSTEM, /* system catalogs */
4141
4142typedef struct ReindexStmt
4143{
4145 ReindexObjectType kind; /* REINDEX_OBJECT_INDEX, REINDEX_OBJECT_TABLE,
4146 * etc. */
4147 RangeVar *relation; /* Table or index to reindex */
4148 const char *name; /* name of database to reindex */
4149 List *params; /* list of DefElem nodes */
4151
4152/* ----------------------
4153 * CREATE CONVERSION Statement
4154 * ----------------------
4155 */
4157{
4159 List *conversion_name; /* Name of the conversion */
4160 char *for_encoding_name; /* source encoding name */
4161 char *to_encoding_name; /* destination encoding name */
4162 List *func_name; /* qualified conversion function name */
4163 bool def; /* is this a default conversion? */
4165
4166/* ----------------------
4167 * CREATE CAST Statement
4168 * ----------------------
4169 */
4179
4180/* ----------------------
4181 * CREATE TRANSFORM Statement
4182 * ----------------------
4183 */
4193
4194/* ----------------------
4195 * PREPARE Statement
4196 * ----------------------
4197 */
4198typedef struct PrepareStmt
4199{
4201 char *name; /* Name of plan, arbitrary */
4202 List *argtypes; /* Types of parameters (List of TypeName) */
4203 Node *query; /* The query itself (as a raw parsetree) */
4205
4206
4207/* ----------------------
4208 * EXECUTE Statement
4209 * ----------------------
4210 */
4211
4212typedef struct ExecuteStmt
4213{
4215 char *name; /* The name of the plan to execute */
4216 List *params; /* Values to assign to parameters */
4218
4219
4220/* ----------------------
4221 * DEALLOCATE Statement
4222 * ----------------------
4223 */
4224typedef struct DeallocateStmt
4225{
4227 /* The name of the plan to remove, NULL if DEALLOCATE ALL */
4229
4230 /*
4231 * True if DEALLOCATE ALL. This is redundant with "name == NULL", but we
4232 * make it a separate field so that exactly this condition (and not the
4233 * precise name) will be accounted for in query jumbling.
4234 */
4235 bool isall;
4236 /* token location, or -1 if unknown */
4239
4240/*
4241 * DROP OWNED statement
4242 */
4249
4250/*
4251 * REASSIGN OWNED statement
4252 */
4259
4260/*
4261 * TS Dictionary stmts: DefineStmt, RenameStmt and DropStmt are default
4262 */
4264{
4266 List *dictname; /* qualified name (list of String) */
4267 List *options; /* List of DefElem nodes */
4269
4270/*
4271 * TS Configuration stmts: DefineStmt, RenameStmt and DropStmt are default
4272 */
4281
4283{
4285 AlterTSConfigType kind; /* ALTER_TSCONFIG_ADD_MAPPING, etc */
4286 List *cfgname; /* qualified name (list of String) */
4287
4288 /*
4289 * dicts will be non-NIL if ADD/ALTER MAPPING was specified. If dicts is
4290 * NIL, but tokentype isn't, DROP MAPPING was specified.
4291 */
4292 List *tokentype; /* list of String */
4293 List *dicts; /* list of list of String */
4294 bool override; /* if true - remove old variant */
4295 bool replace; /* if true - replace dictionary by another */
4296 bool missing_ok; /* for DROP - skip error if missing? */
4298
4299typedef struct PublicationTable
4300{
4302 RangeVar *relation; /* relation to be published */
4303 Node *whereClause; /* qualifications */
4304 List *columns; /* List of columns in a publication table */
4306
4307/*
4308 * Publication object type
4309 */
4311{
4313 PUBLICATIONOBJ_TABLES_IN_SCHEMA, /* All tables in schema */
4314 PUBLICATIONOBJ_TABLES_IN_CUR_SCHEMA, /* All tables in first element of
4315 * search_path */
4316 PUBLICATIONOBJ_CONTINUATION, /* Continuation of previous type */
4318
4320{
4322 PublicationObjSpecType pubobjtype; /* type of this publication object */
4323 char *name;
4325 ParseLoc location; /* token location, or -1 if unknown */
4327
4328/*
4329 * Types of objects supported by FOR ALL publications
4330 */
4336
4338{
4340 PublicationAllObjType pubobjtype; /* type of this publication object */
4341 ParseLoc location; /* token location, or -1 if unknown */
4343
4345{
4347 char *pubname; /* Name of the publication */
4348 List *options; /* List of DefElem nodes */
4349 List *pubobjects; /* Optional list of publication objects */
4350 bool for_all_tables; /* Special publication for all tables in db */
4351 bool for_all_sequences; /* Special publication for all sequences
4352 * in db */
4354
4356{
4357 AP_AddObjects, /* add objects to publication */
4358 AP_DropObjects, /* remove objects from publication */
4359 AP_SetObjects, /* set list of objects */
4361
4363{
4365 char *pubname; /* Name of the publication */
4366
4367 /* parameters used for ALTER PUBLICATION ... WITH */
4368 List *options; /* List of DefElem nodes */
4369
4370 /*
4371 * Parameters used for ALTER PUBLICATION ... ADD/DROP/SET publication
4372 * objects.
4373 */
4374 List *pubobjects; /* Optional list of publication objects */
4375 AlterPublicationAction action; /* What action to perform with the given
4376 * objects */
4378
4380{
4382 char *subname; /* Name of the subscription */
4383 char *conninfo; /* Connection string to publisher */
4384 List *publication; /* One or more publication to subscribe to */
4385 List *options; /* List of DefElem nodes */
4387
4400
4402{
4404 AlterSubscriptionType kind; /* ALTER_SUBSCRIPTION_OPTIONS, etc */
4405 char *subname; /* Name of the subscription */
4406 char *conninfo; /* Connection string to publisher */
4407 List *publication; /* One or more publication to subscribe to */
4408 List *options; /* List of DefElem nodes */
4410
4412{
4414 char *subname; /* Name of the subscription */
4415 bool missing_ok; /* Skip error if missing? */
4416 DropBehavior behavior; /* RESTRICT or CASCADE behavior */
4418
4419typedef struct WaitStmt
4420{
4422 char *lsn_literal; /* LSN string from grammar */
4423 List *options; /* List of DefElem nodes */
4425
4426
4427#endif /* PARSENODES_H */
#define PG_INT32_MAX
Definition c.h:603
uint32 SubTransactionId
Definition c.h:670
int64_t int64
Definition c.h:543
int16_t int16
Definition c.h:541
uint32 bits32
Definition c.h:555
int32_t int32
Definition c.h:542
uint64_t uint64
Definition c.h:547
unsigned int Index
Definition c.h:628
LockWaitPolicy
Definition lockoptions.h:38
LockClauseStrength
Definition lockoptions.h:22
OnConflictAction
Definition nodes.h:427
double Cardinality
Definition nodes.h:262
CmdType
Definition nodes.h:273
NodeTag
Definition nodes.h:27
LimitOption
Definition nodes.h:441
int ParseLoc
Definition nodes.h:250
JoinType
Definition nodes.h:298
RoleSpecType
Definition parsenodes.h:418
@ ROLESPEC_CURRENT_USER
Definition parsenodes.h:421
@ ROLESPEC_CSTRING
Definition parsenodes.h:419
@ ROLESPEC_SESSION_USER
Definition parsenodes.h:422
@ ROLESPEC_CURRENT_ROLE
Definition parsenodes.h:420
@ ROLESPEC_PUBLIC
Definition parsenodes.h:423
AlterSubscriptionType
@ ALTER_SUBSCRIPTION_REFRESH_PUBLICATION
@ ALTER_SUBSCRIPTION_ENABLED
@ ALTER_SUBSCRIPTION_DROP_PUBLICATION
@ ALTER_SUBSCRIPTION_SET_PUBLICATION
@ ALTER_SUBSCRIPTION_REFRESH_SEQUENCES
@ ALTER_SUBSCRIPTION_SKIP
@ ALTER_SUBSCRIPTION_OPTIONS
@ ALTER_SUBSCRIPTION_CONNECTION
@ ALTER_SUBSCRIPTION_ADD_PUBLICATION
PublicationAllObjType
@ PUBLICATION_ALL_TABLES
@ PUBLICATION_ALL_SEQUENCES
AlterDomainType
@ AD_AddConstraint
@ AD_DropConstraint
@ AD_AlterDefault
@ AD_DropNotNull
@ AD_ValidateConstraint
@ AD_SetNotNull
TransactionStmtKind
@ TRANS_STMT_ROLLBACK_TO
@ TRANS_STMT_START
@ TRANS_STMT_SAVEPOINT
@ TRANS_STMT_BEGIN
@ TRANS_STMT_ROLLBACK
@ TRANS_STMT_COMMIT_PREPARED
@ TRANS_STMT_COMMIT
@ TRANS_STMT_ROLLBACK_PREPARED
@ TRANS_STMT_PREPARE
@ TRANS_STMT_RELEASE
WCOKind
@ WCO_RLS_MERGE_UPDATE_CHECK
@ WCO_RLS_CONFLICT_CHECK
@ WCO_RLS_INSERT_CHECK
@ WCO_VIEW_CHECK
@ WCO_RLS_UPDATE_CHECK
@ WCO_RLS_MERGE_DELETE_CHECK
JsonTableColumnType
@ JTC_FORMATTED
@ JTC_FOR_ORDINALITY
@ JTC_NESTED
@ JTC_EXISTS
@ JTC_REGULAR
SortByNulls
Definition parsenodes.h:53
@ SORTBY_NULLS_DEFAULT
Definition parsenodes.h:54
@ SORTBY_NULLS_LAST
Definition parsenodes.h:56
@ SORTBY_NULLS_FIRST
Definition parsenodes.h:55
GroupingSetKind
@ GROUPING_SET_CUBE
@ GROUPING_SET_SIMPLE
@ GROUPING_SET_ROLLUP
@ GROUPING_SET_SETS
@ GROUPING_SET_EMPTY
SetOperation
@ SETOP_INTERSECT
@ SETOP_UNION
@ SETOP_EXCEPT
@ SETOP_NONE
uint64 AclMode
Definition parsenodes.h:74
JsonQuotes
@ JS_QUOTES_KEEP
@ JS_QUOTES_UNSPEC
@ JS_QUOTES_OMIT
A_Expr_Kind
Definition parsenodes.h:329
@ AEXPR_BETWEEN
Definition parsenodes.h:340
@ AEXPR_NULLIF
Definition parsenodes.h:335
@ AEXPR_NOT_DISTINCT
Definition parsenodes.h:334
@ AEXPR_BETWEEN_SYM
Definition parsenodes.h:342
@ AEXPR_NOT_BETWEEN_SYM
Definition parsenodes.h:343
@ AEXPR_ILIKE
Definition parsenodes.h:338
@ AEXPR_IN
Definition parsenodes.h:336
@ AEXPR_NOT_BETWEEN
Definition parsenodes.h:341
@ AEXPR_DISTINCT
Definition parsenodes.h:333
@ AEXPR_SIMILAR
Definition parsenodes.h:339
@ AEXPR_LIKE
Definition parsenodes.h:337
@ AEXPR_OP
Definition parsenodes.h:330
@ AEXPR_OP_ANY
Definition parsenodes.h:331
@ AEXPR_OP_ALL
Definition parsenodes.h:332
FunctionParameterMode
@ FUNC_PARAM_IN
@ FUNC_PARAM_DEFAULT
@ FUNC_PARAM_OUT
@ FUNC_PARAM_INOUT
@ FUNC_PARAM_TABLE
@ FUNC_PARAM_VARIADIC
AlterTSConfigType
@ ALTER_TSCONFIG_ALTER_MAPPING_FOR_TOKEN
@ ALTER_TSCONFIG_REPLACE_DICT_FOR_TOKEN
@ ALTER_TSCONFIG_REPLACE_DICT
@ ALTER_TSCONFIG_ADD_MAPPING
@ ALTER_TSCONFIG_DROP_MAPPING
PublicationObjSpecType
@ PUBLICATIONOBJ_TABLES_IN_CUR_SCHEMA
@ PUBLICATIONOBJ_TABLES_IN_SCHEMA
@ PUBLICATIONOBJ_TABLE
@ PUBLICATIONOBJ_CONTINUATION
PartitionStrategy
Definition parsenodes.h:900
@ PARTITION_STRATEGY_HASH
Definition parsenodes.h:903
@ PARTITION_STRATEGY_LIST
Definition parsenodes.h:901
@ PARTITION_STRATEGY_RANGE
Definition parsenodes.h:902
ImportForeignSchemaType
@ FDW_IMPORT_SCHEMA_LIMIT_TO
@ FDW_IMPORT_SCHEMA_ALL
@ FDW_IMPORT_SCHEMA_EXCEPT
AlterPublicationAction
@ AP_DropObjects
@ AP_SetObjects
@ AP_AddObjects
QuerySource
Definition parsenodes.h:35
@ QSRC_NON_INSTEAD_RULE
Definition parsenodes.h:40
@ QSRC_PARSER
Definition parsenodes.h:37
@ QSRC_QUAL_INSTEAD_RULE
Definition parsenodes.h:39
@ QSRC_ORIGINAL
Definition parsenodes.h:36
@ QSRC_INSTEAD_RULE
Definition parsenodes.h:38
RTEKind
@ RTE_JOIN
@ RTE_CTE
@ RTE_NAMEDTUPLESTORE
@ RTE_VALUES
@ RTE_SUBQUERY
@ RTE_RESULT
@ RTE_FUNCTION
@ RTE_TABLEFUNC
@ RTE_GROUP
@ RTE_RELATION
DefElemAction
Definition parsenodes.h:833
@ DEFELEM_UNSPEC
Definition parsenodes.h:834
@ DEFELEM_DROP
Definition parsenodes.h:837
@ DEFELEM_SET
Definition parsenodes.h:835
@ DEFELEM_ADD
Definition parsenodes.h:836
ConstrType
@ CONSTR_ATTR_ENFORCED
@ CONSTR_FOREIGN
@ CONSTR_ATTR_DEFERRED
@ CONSTR_IDENTITY
@ CONSTR_UNIQUE
@ CONSTR_ATTR_NOT_DEFERRABLE
@ CONSTR_DEFAULT
@ CONSTR_NOTNULL
@ CONSTR_ATTR_IMMEDIATE
@ CONSTR_CHECK
@ CONSTR_NULL
@ CONSTR_GENERATED
@ CONSTR_EXCLUSION
@ CONSTR_ATTR_DEFERRABLE
@ CONSTR_ATTR_NOT_ENFORCED
@ CONSTR_PRIMARY
PartitionRangeDatumKind
Definition parsenodes.h:952
@ PARTITION_RANGE_DATUM_MAXVALUE
Definition parsenodes.h:955
@ PARTITION_RANGE_DATUM_VALUE
Definition parsenodes.h:954
@ PARTITION_RANGE_DATUM_MINVALUE
Definition parsenodes.h:953
FetchDirection
@ FETCH_RELATIVE
@ FETCH_ABSOLUTE
@ FETCH_FORWARD
@ FETCH_BACKWARD
VariableSetKind
@ VAR_SET_DEFAULT
@ VAR_RESET
@ VAR_SET_MULTI
@ VAR_SET_VALUE
@ VAR_SET_CURRENT
@ VAR_RESET_ALL
DropBehavior
@ DROP_CASCADE
@ DROP_RESTRICT
ObjectType
@ OBJECT_EVENT_TRIGGER
@ OBJECT_FDW
@ OBJECT_TSPARSER
@ OBJECT_COLLATION
@ OBJECT_USER_MAPPING
@ OBJECT_ACCESS_METHOD
@ OBJECT_OPCLASS
@ OBJECT_DEFACL
@ OBJECT_AGGREGATE
@ OBJECT_MATVIEW
@ OBJECT_SCHEMA
@ OBJECT_POLICY
@ OBJECT_OPERATOR
@ OBJECT_FOREIGN_TABLE
@ OBJECT_TSCONFIGURATION
@ OBJECT_OPFAMILY
@ OBJECT_DOMAIN
@ OBJECT_COLUMN
@ OBJECT_TABLESPACE
@ OBJECT_ROLE
@ OBJECT_ROUTINE
@ OBJECT_LARGEOBJECT
@ OBJECT_PUBLICATION_NAMESPACE
@ OBJECT_PROCEDURE
@ OBJECT_EXTENSION
@ OBJECT_INDEX
@ OBJECT_DEFAULT
@ OBJECT_DATABASE
@ OBJECT_SEQUENCE
@ OBJECT_TSTEMPLATE
@ OBJECT_LANGUAGE
@ OBJECT_AMOP
@ OBJECT_PUBLICATION_REL
@ OBJECT_FOREIGN_SERVER
@ OBJECT_TSDICTIONARY
@ OBJECT_ATTRIBUTE
@ OBJECT_PUBLICATION
@ OBJECT_RULE
@ OBJECT_CONVERSION
@ OBJECT_AMPROC
@ OBJECT_TABLE
@ OBJECT_VIEW
@ OBJECT_PARAMETER_ACL
@ OBJECT_TYPE
@ OBJECT_FUNCTION
@ OBJECT_TABCONSTRAINT
@ OBJECT_DOMCONSTRAINT
@ OBJECT_SUBSCRIPTION
@ OBJECT_STATISTIC_EXT
@ OBJECT_CAST
@ OBJECT_TRIGGER
@ OBJECT_TRANSFORM
ReindexObjectType
@ REINDEX_OBJECT_DATABASE
@ REINDEX_OBJECT_INDEX
@ REINDEX_OBJECT_SCHEMA
@ REINDEX_OBJECT_SYSTEM
@ REINDEX_OBJECT_TABLE
AlterTableType
@ AT_AddIndexConstraint
@ AT_MergePartitions
@ AT_DropOf
@ AT_SetOptions
@ AT_DropIdentity
@ AT_DisableTrigUser
@ AT_DropNotNull
@ AT_AddOf
@ AT_ResetOptions
@ AT_ReplicaIdentity
@ AT_ReplaceRelOptions
@ AT_EnableRowSecurity
@ AT_AddColumnToView
@ AT_ResetRelOptions
@ AT_EnableReplicaTrig
@ AT_DropOids
@ AT_SetIdentity
@ AT_ReAddStatistics
@ AT_SetUnLogged
@ AT_DisableTrig
@ AT_SetCompression
@ AT_DropExpression
@ AT_AddIndex
@ AT_EnableReplicaRule
@ AT_ReAddIndex
@ AT_DropConstraint
@ AT_SetNotNull
@ AT_ClusterOn
@ AT_AddIdentity
@ AT_ForceRowSecurity
@ AT_EnableAlwaysRule
@ AT_SetAccessMethod
@ AT_AlterColumnType
@ AT_DetachPartitionFinalize
@ AT_AddInherit
@ AT_ReAddDomainConstraint
@ AT_EnableTrig
@ AT_DropColumn
@ AT_ReAddComment
@ AT_AlterColumnGenericOptions
@ AT_DisableTrigAll
@ AT_EnableRule
@ AT_NoForceRowSecurity
@ AT_DetachPartition
@ AT_SetStatistics
@ AT_AttachPartition
@ AT_AddConstraint
@ AT_DropInherit
@ AT_EnableAlwaysTrig
@ AT_SetLogged
@ AT_SetStorage
@ AT_DisableRule
@ AT_DisableRowSecurity
@ AT_SetRelOptions
@ AT_ChangeOwner
@ AT_EnableTrigUser
@ AT_SetExpression
@ AT_ReAddConstraint
@ AT_SetTableSpace
@ AT_GenericOptions
@ AT_ColumnDefault
@ AT_CookedColumnDefault
@ AT_AlterConstraint
@ AT_EnableTrigAll
@ AT_SplitPartition
@ AT_DropCluster
@ AT_ValidateConstraint
@ AT_AddColumn
GrantTargetType
@ ACL_TARGET_DEFAULTS
@ ACL_TARGET_OBJECT
@ ACL_TARGET_ALL_IN_SCHEMA
FetchDirectionKeywords
@ FETCH_KEYWORD_LAST
@ FETCH_KEYWORD_RELATIVE
@ FETCH_KEYWORD_PRIOR
@ FETCH_KEYWORD_FIRST
@ FETCH_KEYWORD_NEXT
@ FETCH_KEYWORD_FORWARD_ALL
@ FETCH_KEYWORD_NONE
@ FETCH_KEYWORD_ABSOLUTE
@ FETCH_KEYWORD_FORWARD
@ FETCH_KEYWORD_BACKWARD
@ FETCH_KEYWORD_ALL
@ FETCH_KEYWORD_BACKWARD_ALL
DiscardMode
@ DISCARD_ALL
@ DISCARD_PLANS
@ DISCARD_SEQUENCES
@ DISCARD_TEMP
ReturningOptionKind
@ RETURNING_OPTION_NEW
@ RETURNING_OPTION_OLD
SortByDir
Definition parsenodes.h:45
@ SORTBY_USING
Definition parsenodes.h:49
@ SORTBY_DESC
Definition parsenodes.h:48
@ SORTBY_ASC
Definition parsenodes.h:47
@ SORTBY_DEFAULT
Definition parsenodes.h:46
RoleStmtType
@ ROLESTMT_ROLE
@ ROLESTMT_USER
@ ROLESTMT_GROUP
TableLikeOption
Definition parsenodes.h:788
@ CREATE_TABLE_LIKE_COMMENTS
Definition parsenodes.h:789
@ CREATE_TABLE_LIKE_GENERATED
Definition parsenodes.h:793
@ CREATE_TABLE_LIKE_IDENTITY
Definition parsenodes.h:794
@ CREATE_TABLE_LIKE_COMPRESSION
Definition parsenodes.h:790
@ CREATE_TABLE_LIKE_STORAGE
Definition parsenodes.h:797
@ CREATE_TABLE_LIKE_ALL
Definition parsenodes.h:798
@ CREATE_TABLE_LIKE_INDEXES
Definition parsenodes.h:795
@ CREATE_TABLE_LIKE_DEFAULTS
Definition parsenodes.h:792
@ CREATE_TABLE_LIKE_STATISTICS
Definition parsenodes.h:796
@ CREATE_TABLE_LIKE_CONSTRAINTS
Definition parsenodes.h:791
SetQuantifier
Definition parsenodes.h:61
@ SET_QUANTIFIER_ALL
Definition parsenodes.h:63
@ SET_QUANTIFIER_DISTINCT
Definition parsenodes.h:64
@ SET_QUANTIFIER_DEFAULT
Definition parsenodes.h:62
ViewCheckOption
@ NO_CHECK_OPTION
@ CASCADED_CHECK_OPTION
@ LOCAL_CHECK_OPTION
CTEMaterialize
@ CTEMaterializeNever
@ CTEMaterializeAlways
@ CTEMaterializeDefault
unsigned int Oid
static int fb(int x)
XmlOptionType
Definition primnodes.h:1617
JsonWrapper
Definition primnodes.h:1775
OnCommitAction
Definition primnodes.h:58
JsonExprOp
Definition primnodes.h:1827
CoercionForm
Definition primnodes.h:766
OverridingKind
Definition primnodes.h:28
MergeMatchKind
Definition primnodes.h:2021
CoercionContext
Definition primnodes.h:746
Oid RelFileNumber
Definition relpath.h:25
NodeTag type
Definition parsenodes.h:517
List * elements
Definition parsenodes.h:518
ParseLoc list_start
Definition parsenodes.h:519
ParseLoc list_end
Definition parsenodes.h:520
ParseLoc location
Definition parsenodes.h:521
bool isnull
Definition parsenodes.h:388
union ValUnion val
Definition parsenodes.h:387
ParseLoc location
Definition parsenodes.h:389
pg_node_attr(custom_copy_equal, custom_read_write, custom_query_jumble) NodeTag type
ParseLoc location
Definition parsenodes.h:363
ParseLoc rexpr_list_end
Definition parsenodes.h:362
Node * lexpr
Definition parsenodes.h:353
ParseLoc rexpr_list_start
Definition parsenodes.h:361
pg_node_attr(custom_read_write) NodeTag type
List * name
Definition parsenodes.h:352
A_Expr_Kind kind
Definition parsenodes.h:351
Node * rexpr
Definition parsenodes.h:354
bool is_slice
Definition parsenodes.h:485
Node * uidx
Definition parsenodes.h:487
NodeTag type
Definition parsenodes.h:484
Node * lidx
Definition parsenodes.h:486
List * indirection
Definition parsenodes.h:509
NodeTag type
Definition parsenodes.h:473
char * priv_name
NodeTag type
List * cols
VariableSetStmt * setstmt
AlterDomainType subtype
DropBehavior behavior
char * newValNeighbor
bool skipIfNewValExists
List * func_options
ObjectWithArgs * func
ObjectType objtype
ObjectWithArgs * opername
RangeVar * relation
RoleSpec * newowner
ObjectType objectType
RangeVar * table
AlterPublicationAction action
RoleSpec * role
VariableSetStmt * setstmt
RoleSpec * role
RangeVar * sequence
Node * stxstattarget
AlterSubscriptionType kind
VariableSetStmt * setstmt
AlterTSConfigType kind
RoleSpec * newowner
DropBehavior behavior
AlterTableType subtype
RangeVar * relation
ObjectType objtype
char * cycle_path_column
ParseLoc location
Node * cycle_mark_default
List * cycle_col_list
char * cycle_mark_column
Node * cycle_mark_value
ParseLoc location
char * search_seq_column
bool search_breadth_first
List * search_col_list
pg_node_attr(nodetag_only) NodeTag type
FuncExpr * funcexpr
NodeTag type
List * outargs
FuncCall *funccall pg_node_attr(query_jumble_ignore)
char * indexname
RangeVar * relation
NodeTag type
List * params
List * collname
Definition parsenodes.h:410
ParseLoc location
Definition parsenodes.h:411
bool is_not_null
Definition parsenodes.h:759
CollateClause * collClause
Definition parsenodes.h:769
char identity
Definition parsenodes.h:765
RangeVar * identitySequence
Definition parsenodes.h:766
List * constraints
Definition parsenodes.h:771
Node * cooked_default
Definition parsenodes.h:764
char * storage_name
Definition parsenodes.h:762
char * colname
Definition parsenodes.h:754
TypeName * typeName
Definition parsenodes.h:755
char generated
Definition parsenodes.h:768
NodeTag type
Definition parsenodes.h:753
bool is_from_type
Definition parsenodes.h:760
List * fdwoptions
Definition parsenodes.h:772
Node * raw_default
Definition parsenodes.h:763
char storage
Definition parsenodes.h:761
bool is_local
Definition parsenodes.h:758
int16 inhcount
Definition parsenodes.h:757
char * compression
Definition parsenodes.h:756
ParseLoc location
Definition parsenodes.h:773
ParseLoc location
Definition parsenodes.h:312
List * fields
Definition parsenodes.h:311
NodeTag type
Definition parsenodes.h:310
char * comment
ObjectType objtype
NodeTag type
Node * object
int cterefcount pg_node_attr(query_jumble_ignore)
List *aliascolnames pg_node_attr(query_jumble_ignore)
List *ctecoltypes pg_node_attr(query_jumble_ignore)
CTECycleClause *cycle_clause pg_node_attr(query_jumble_ignore)
List *ctecoltypmods pg_node_attr(query_jumble_ignore)
CTESearchClause *search_clause pg_node_attr(query_jumble_ignore)
CTEMaterialize ctematerialized
List *ctecolnames pg_node_attr(query_jumble_ignore)
List *ctecolcollations pg_node_attr(query_jumble_ignore)
ParseLoc location
bool cterecursive pg_node_attr(query_jumble_ignore)
RangeVar * typevar
bool initdeferred
List * exclusions
ParseLoc location
bool reset_default_tblspc
List * keys
List * pk_attrs
List * fk_del_set_cols
bool fk_with_period
Node * where_clause
char * indexname
char generated_kind
char * indexspace
ConstrType contype
char * access_method
Oid old_pktable_oid
bool is_no_inherit
List * options
char fk_upd_action
List * old_conpfeqop
bool is_enforced
char fk_matchtype
bool nulls_not_distinct
bool pk_with_period
char * cooked_expr
bool initially_valid
bool skip_validation
bool without_overlaps
bool deferrable
NodeTag type
Node * raw_expr
char * conname
char generated_when
RangeVar * pktable
List * including
char fk_del_action
List * fk_attrs
bool is_program
RangeVar * relation
List * options
bool is_from
char * filename
NodeTag type
List * attlist
Node * whereClause
Node * query
List * handler_name
TypeName * sourcetype
TypeName * targettype
CoercionContext context
ObjectWithArgs * func
TypeName * typeName
CollateClause * collClause
List * func_options
TypeName * returnType
ObjectWithArgs * name
TypeName * storedtype
TypeName * datatype
RangeVar * table
RoleStmtType stmt_type
RoleSpec * authrole
RangeVar * sequence
List * tableElts
List * nnconstraints
TypeName * ofTypename
OnCommitAction oncommit
List * options
bool if_not_exists
List * inhRelations
RangeVar * relation
char * tablespacename
PartitionSpec * partspec
NodeTag type
PartitionBoundSpec * partbound
char * accessMethod
List * constraints
IntoClause * into
ObjectType objtype
ObjectWithArgs * tosql
ObjectWithArgs * fromsql
List * transitionRels
RangeVar * constrrel
RangeVar * relation
char *name pg_node_attr(query_jumble_ignore)
ParseLoc location pg_node_attr(query_jumble_location)
char * defnamespace
Definition parsenodes.h:843
NodeTag type
Definition parsenodes.h:842
DefElemAction defaction
Definition parsenodes.h:847
char * defname
Definition parsenodes.h:844
ParseLoc location
Definition parsenodes.h:848
Node * arg
Definition parsenodes.h:845
List * definition
List * defnames
List * args
NodeTag type
ObjectType kind
bool if_not_exists
ReturningClause * returningClause
WithClause * withClause
Node * whereClause
RangeVar * relation
List * usingClause
NodeTag type
NodeTag type
DiscardMode target
NodeTag type
List * args
DropBehavior behavior
bool missing_ok
List * objects
ObjectType removeType
bool concurrent
DropBehavior behavior
NodeTag type
DropBehavior behavior
List * options
char * dbname
bool missing_ok
NodeTag type
List * params
NodeTag type
NodeTag type
List * options
long howMany pg_node_attr(query_jumble_ignore)
ParseLoc location pg_node_attr(query_jumble_location)
FetchDirection direction
char * portalname
FetchDirectionKeywords direction_keyword
NodeTag type
Definition value.h:48
bool agg_within_group
Definition parsenodes.h:457
CoercionForm funcformat
Definition parsenodes.h:461
Node * agg_filter
Definition parsenodes.h:454
List * agg_order
Definition parsenodes.h:453
List * funcname
Definition parsenodes.h:451
List * args
Definition parsenodes.h:452
bool agg_star
Definition parsenodes.h:458
int ignore_nulls
Definition parsenodes.h:456
bool agg_distinct
Definition parsenodes.h:459
NodeTag type
Definition parsenodes.h:450
ParseLoc location
Definition parsenodes.h:462
bool func_variadic
Definition parsenodes.h:460
struct WindowDef * over
Definition parsenodes.h:455
TypeName * argType
FunctionParameterMode mode
DropBehavior behavior
RoleSpec * grantor
List * grantee_roles
List * granted_roles
ObjectType objtype
bool is_grant
List * objects
bool grant_option
List * grantees
List * privileges
GrantTargetType targtype
NodeTag type
DropBehavior behavior
RoleSpec * grantor
NodeTag type
List * content
GroupingSetKind kind pg_node_attr(query_jumble_ignore)
ParseLoc location
ImportForeignSchemaType list_type
Node * expr
Definition parsenodes.h:812
SortByDir ordering
Definition parsenodes.h:817
List * opclassopts
Definition parsenodes.h:816
NodeTag type
Definition parsenodes.h:810
char * indexcolname
Definition parsenodes.h:813
ParseLoc location
Definition parsenodes.h:819
SortByNulls nulls_ordering
Definition parsenodes.h:818
List * opclass
Definition parsenodes.h:815
char * name
Definition parsenodes.h:811
List * collation
Definition parsenodes.h:814
bool reset_default_tblspc
NodeTag type
bool deferrable
List * indexParams
bool initdeferred
RangeVar * relation
SubTransactionId oldFirstRelfilelocatorSubid
bool iswithoutoverlaps
bool transformed
List * options
char * tableSpace
SubTransactionId oldCreateSubid
bool isconstraint
List * excludeOpNames
bool nulls_not_distinct
bool concurrent
char * idxname
Node * whereClause
bool if_not_exists
char * accessMethod
char * idxcomment
RelFileNumber oldNumber
List * indexIncludingParams
NodeTag type
ParseLoc location
char * conname
List * indexElems
Node * whereClause
pg_node_attr(nodetag_only) NodeTag type
OnConflictClause * onConflictClause
Node * selectStmt
ReturningClause * returningClause
WithClause * withClause
NodeTag type
RangeVar * relation
List * cols
struct WindowDef * over
JsonOutput * output
JsonValueExpr * val
bool absent_on_null
JsonValueExpr * arg
JsonAggConstructor * constructor
JsonOutput * output
JsonOutput * output
char * column_name
JsonWrapper wrapper
JsonQuotes quotes
JsonExprOp op
JsonBehavior * on_empty
ParseLoc location
Node * pathspec
JsonBehavior * on_error
JsonValueExpr * context_item
JsonValueExpr * value
JsonAggConstructor * constructor
JsonKeyValue * arg
JsonReturning * returning
TypeName * typeName
NodeTag type
JsonValueExpr * expr
ParseLoc location
JsonOutput * output
ParseLoc location
JsonOutput * output
JsonOutput * output
JsonValueExpr * expr
ParseLoc location
JsonTableColumnType coltype
JsonBehavior * on_empty
JsonWrapper wrapper
JsonBehavior * on_error
JsonQuotes quotes
JsonFormat * format
TypeName * typeName
JsonTablePathSpec * pathspec
ParseLoc name_location
JsonBehavior * on_error
List * columns
JsonTablePathSpec * pathspec
Alias * alias
NodeTag type
List * passing
JsonValueExpr * context_item
ParseLoc location
Definition pg_list.h:54
NodeTag type
char * conditionname
NodeTag type
char * filename
NodeTag type
bool nowait
List * relations
List * lockedRels
Definition parsenodes.h:863
LockClauseStrength strength
Definition parsenodes.h:864
LockWaitPolicy waitPolicy
Definition parsenodes.h:865
ReturningClause * returningClause
Node * sourceRelation
List * mergeWhenClauses
RangeVar * relation
Node * joinCondition
WithClause * withClause
NodeTag type
CmdType commandType
MergeMatchKind matchKind
Definition nodes.h:135
char * payload
char * conditionname
NodeTag type
InferClause * infer
OnConflictAction action
LockClauseStrength lockStrength
SelectStmt * val
ParseLoc location
List * indirection
ParseLoc location
Definition parsenodes.h:322
NodeTag type
Definition parsenodes.h:320
PartitionBoundSpec * bound
Definition parsenodes.h:993
List * partlist
RangeVar * name
Definition parsenodes.h:990
NodeTag type
Definition parsenodes.h:987
List * collation
Definition parsenodes.h:894
ParseLoc location
Definition parsenodes.h:896
PartitionRangeDatumKind kind
Definition parsenodes.h:962
List * partParams
Definition parsenodes.h:915
ParseLoc location
Definition parsenodes.h:916
PartitionStrategy strategy
Definition parsenodes.h:914
List * argtypes
NodeTag type
PublicationAllObjType pubobjtype
PublicationObjSpecType pubobjtype
PublicationTable * pubtable
RangeVar * relation
List * rowMarks
Definition parsenodes.h:234
int mergeTargetRelation pg_node_attr(query_jumble_ignore)
bool hasAggs pg_node_attr(query_jumble_ignore)
bool groupDistinct
Definition parsenodes.h:217
bool hasRecursive pg_node_attr(query_jumble_ignore)
Node * mergeJoinCondition
Definition parsenodes.h:196
Node * limitCount
Definition parsenodes.h:231
FromExpr * jointree
Definition parsenodes.h:182
List * returningList
Definition parsenodes.h:214
bool canSetTag pg_node_attr(query_jumble_ignore)
Node * setOperations
Definition parsenodes.h:236
bool hasSubLinks pg_node_attr(query_jumble_ignore)
List * cteList
Definition parsenodes.h:173
OnConflictExpr * onConflict
Definition parsenodes.h:203
char *returningOldAlias pg_node_attr(query_jumble_ignore)
OverridingKind override pg_node_attr(query_jumble_ignore)
List * groupClause
Definition parsenodes.h:216
List *rteperminfos pg_node_attr(query_jumble_ignore)
bool hasTargetSRFs pg_node_attr(query_jumble_ignore)
bool hasGroupRTE pg_node_attr(query_jumble_ignore)
int resultRelation pg_node_attr(query_jumble_ignore)
Node * havingQual
Definition parsenodes.h:222
List * rtable
Definition parsenodes.h:175
List *withCheckOptions pg_node_attr(query_jumble_ignore)
ParseLoc stmt_len pg_node_attr(query_jumble_ignore)
bool hasDistinctOn pg_node_attr(query_jumble_ignore)
Node * limitOffset
Definition parsenodes.h:230
List *constraintDeps pg_node_attr(query_jumble_ignore)
bool isReturn pg_node_attr(query_jumble_ignore)
bool hasWindowFuncs pg_node_attr(query_jumble_ignore)
CmdType commandType
Definition parsenodes.h:121
LimitOption limitOption
Definition parsenodes.h:232
Node * utilityStmt
Definition parsenodes.h:141
List * mergeActionList
Definition parsenodes.h:185
bool hasModifyingCTE pg_node_attr(query_jumble_ignore)
NodeTag type
Definition parsenodes.h:119
List * windowClause
Definition parsenodes.h:224
List * targetList
Definition parsenodes.h:198
List * groupingSets
Definition parsenodes.h:220
bool groupByAll
Definition parsenodes.h:218
List * distinctClause
Definition parsenodes.h:226
bool hasForUpdate pg_node_attr(query_jumble_ignore)
List * sortClause
Definition parsenodes.h:228
char *returningNewAlias pg_node_attr(query_jumble_ignore)
ParseLoc stmt_location
Definition parsenodes.h:255
int64 queryId pg_node_attr(equal_ignore, query_jumble_ignore, read_write_ignore, read_as(0))
bool hasRowSecurity pg_node_attr(query_jumble_ignore)
QuerySource querySource pg_node_attr(query_jumble_ignore)
Bitmapset * selectedCols
Bitmapset * insertedCols
Bitmapset * updatedCols
Alias * alias
Definition parsenodes.h:672
List * coldeflist
Definition parsenodes.h:673
List * functions
Definition parsenodes.h:671
TypeName * typeName
Definition parsenodes.h:705
List * namespaces
Definition parsenodes.h:689
ParseLoc location
Definition parsenodes.h:692
ParseLoc location
Definition parsenodes.h:730
List *colcollations pg_node_attr(query_jumble_ignore)
List *joinrightcols pg_node_attr(query_jumble_ignore)
Cardinality enrtuples pg_node_attr(query_jumble_ignore)
TableFunc * tablefunc
Alias *alias pg_node_attr(query_jumble_ignore)
List *joinleftcols pg_node_attr(query_jumble_ignore)
bool inFromCl pg_node_attr(query_jumble_ignore)
bool lateral pg_node_attr(query_jumble_ignore)
List *joinaliasvars pg_node_attr(query_jumble_ignore)
bool security_barrier pg_node_attr(query_jumble_ignore)
struct TableSampleClause * tablesample
Alias *eref pg_node_attr(custom_query_jumble)
Query * subquery
List * groupexprs
List *coltypmods pg_node_attr(query_jumble_ignore)
List * values_lists
List *securityQuals pg_node_attr(query_jumble_ignore)
JoinType jointype
int rellockmode pg_node_attr(query_jumble_ignore)
pg_node_attr(custom_read_write) NodeTag type
char relkind pg_node_attr(query_jumble_ignore)
int joinmergedcols pg_node_attr(query_jumble_ignore)
Index perminfoindex pg_node_attr(query_jumble_ignore)
bool self_reference pg_node_attr(query_jumble_ignore)
List *coltypes pg_node_attr(query_jumble_ignore)
Oid relid pg_node_attr(query_jumble_ignore)
RTEKind rtekind
Alias *join_using_alias pg_node_attr(query_jumble_ignore)
List *funccolcollations pg_node_attr(query_jumble_ignore)
Bitmapset *funcparams pg_node_attr(query_jumble_ignore)
List *funccolnames pg_node_attr(query_jumble_ignore)
int funccolcount pg_node_attr(query_jumble_ignore)
List *funccoltypes pg_node_attr(query_jumble_ignore)
List *funccoltypmods pg_node_attr(query_jumble_ignore)
ParseLoc stmt_location
ParseLoc stmt_len
pg_node_attr(no_query_jumble) NodeTag type
Node * stmt
RoleSpec * newrole
RangeVar * relation
const char * name
ReindexObjectType kind
RangeVar * relation
List * params
NodeTag type
RangeVar * relation
bool missing_ok
ObjectType relationType
DropBehavior behavior
ObjectType renameType
NodeTag type
char * newname
char * subname
Node * object
Node * val
Definition parsenodes.h:547
ParseLoc location
Definition parsenodes.h:548
List * indirection
Definition parsenodes.h:546
char * name
Definition parsenodes.h:545
NodeTag type
Definition parsenodes.h:544
NodeTag type
Node * returnval
ReturningOptionKind option
ParseLoc location
ParseLoc location
Definition parsenodes.h:431
RoleSpecType roletype
Definition parsenodes.h:429
NodeTag type
Definition parsenodes.h:428
char * rolename
Definition parsenodes.h:430
LockClauseStrength strength
LockWaitPolicy waitPolicy
char * rulename
Node * whereClause
bool instead
RangeVar * relation
bool replace
CmdType event
List * actions
NodeTag type
ObjectType objtype
char * provider
LimitOption limitOption
List * sortClause
List * targetList
IntoClause * intoClause
Node * limitOffset
bool groupDistinct
List * fromClause
bool groupByAll
NodeTag type
List * groupClause
Node * havingClause
List * lockingClause
Node * limitCount
List * windowClause
List * distinctClause
List * valuesLists
struct SelectStmt * larg
struct SelectStmt * rarg
Node * whereClause
SetOperation op
WithClause * withClause
List *colCollations pg_node_attr(query_jumble_ignore)
List *colTypes pg_node_attr(query_jumble_ignore)
List *groupClauses pg_node_attr(query_jumble_ignore)
List *colTypmods pg_node_attr(query_jumble_ignore)
SetOperation op
PartitionBoundSpec * bound
Definition parsenodes.h:978
SortByNulls sortby_nulls
Definition parsenodes.h:576
Node * node
Definition parsenodes.h:574
NodeTag type
Definition parsenodes.h:573
List * useOp
Definition parsenodes.h:577
SortByDir sortby_dir
Definition parsenodes.h:575
ParseLoc location
Definition parsenodes.h:578
bool hashable pg_node_attr(query_jumble_ignore)
NodeTag type
char * name
Node * expr
Definition value.h:64
RangeVar * relation
Definition parsenodes.h:782
TransactionStmtKind kind
ParseLoc location pg_node_attr(query_jumble_location)
char *savepoint_name pg_node_attr(query_jumble_ignore)
char *gid pg_node_attr(query_jumble_ignore)
List * relations
DropBehavior behavior
TypeName * typeName
Definition parsenodes.h:399
ParseLoc location
Definition parsenodes.h:400
Node * arg
Definition parsenodes.h:398
NodeTag type
Definition parsenodes.h:397
bool setof
Definition parsenodes.h:287
Oid typeOid
Definition parsenodes.h:286
bool pct_type
Definition parsenodes.h:288
List * names
Definition parsenodes.h:285
NodeTag type
Definition parsenodes.h:284
List * arrayBounds
Definition parsenodes.h:291
int32 typemod
Definition parsenodes.h:290
ParseLoc location
Definition parsenodes.h:292
List * typmods
Definition parsenodes.h:289
char * conditionname
List * targetList
List * fromClause
NodeTag type
Node * whereClause
ReturningClause * returningClause
RangeVar * relation
WithClause * withClause
RangeVar * relation
NodeTag type
List * options
bool is_vacuumcmd
List * rels
ParseLoc location pg_node_attr(query_jumble_location)
VariableSetKind kind
pg_node_attr(custom_query_jumble) NodeTag type
bool replace
List * options
Node * query
List * aliases
RangeVar * view
NodeTag type
ViewCheckOption withCheckOption
NodeTag type
List * options
char * lsn_literal
bool inRangeNullsFirst pg_node_attr(query_jumble_ignore)
bool inRangeAsc pg_node_attr(query_jumble_ignore)
Node * startOffset
Oid inRangeColl pg_node_attr(query_jumble_ignore)
List * partitionClause
bool copiedOrder pg_node_attr(query_jumble_ignore)
char *refname pg_node_attr(query_jumble_ignore)
Oid startInRangeFunc pg_node_attr(query_jumble_ignore)
Oid endInRangeFunc pg_node_attr(query_jumble_ignore)
char *name pg_node_attr(query_jumble_ignore)
Node * endOffset
List * orderClause
List * orderClause
Definition parsenodes.h:595
ParseLoc location
Definition parsenodes.h:599
NodeTag type
Definition parsenodes.h:591
List * partitionClause
Definition parsenodes.h:594
Node * startOffset
Definition parsenodes.h:597
char * refname
Definition parsenodes.h:593
Node * endOffset
Definition parsenodes.h:598
int frameOptions
Definition parsenodes.h:596
char * name
Definition parsenodes.h:592
List * ctes
NodeTag type
ParseLoc location
ParseLoc location
Definition parsenodes.h:878
TypeName * typeName
Definition parsenodes.h:876
NodeTag type
Definition parsenodes.h:873
XmlOptionType xmloption
Definition parsenodes.h:874
BitString bsval
Definition parsenodes.h:379
Node node
Definition parsenodes.h:374
Float fval
Definition parsenodes.h:376
String sval
Definition parsenodes.h:378
Boolean boolval
Definition parsenodes.h:377
Integer ival
Definition parsenodes.h:375
const char * type
const char * name