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 * We ignore fields for query jumbling if they are not semantically
113 * significant (such as alias names). We also ignore anything that can
114 * be deduced from other fields or child nodes, else we'd just be
115 * double-hashing that piece of information. In some places query jumbling
116 * deliberately ignores fields that are semantically significant, such as
117 * Const values, because we have made a policy decision to combine queries
118 * that differ only in those respects.
119 */
120typedef struct Query
121{
123
124 CmdType commandType; /* select|insert|update|delete|merge|utility */
125
126 /* where did I come from? */
128
129 /*
130 * query identifier (can be set by plugins); ignored for equal, as it
131 * might not be set; also not stored. This is the output of query
132 * jumbling, hence it must be ignored as an input.
133 *
134 * We store this as a signed value as this is the form it's displayed to
135 * users in places such as EXPLAIN and pg_stat_statements. Primarily this
136 * is done due to lack of an SQL type to represent the full range of
137 * uint64.
138 */
140
141 /* do I set the command result tag? */
143
144 Node *utilityStmt; /* non-null if commandType == CMD_UTILITY */
145
146 /*
147 * rtable index of target relation for INSERT/UPDATE/DELETE/MERGE; 0 for
148 * SELECT.
149 */
151
152 /* FOR PORTION OF clause for UPDATE/DELETE */
154
155 /* has aggregates in tlist or havingQual */
157 /* has window functions in tlist */
159 /* has set-returning functions in tlist */
161 /* has subquery SubLink */
163 /* distinctClause is from DISTINCT ON */
165 /* WITH RECURSIVE was specified */
167 /* has INSERT/UPDATE/DELETE/MERGE in WITH */
168 bool hasModifyingCTE pg_node_attr(query_jumble_ignore);
169 /* FOR [KEY] UPDATE/SHARE was specified */
171 /* rewriter has applied some RLS policy */
172 bool hasRowSecurity pg_node_attr(query_jumble_ignore);
173 /* parser has added an RTE_GROUP RTE */
175 /* is a RETURN statement */
177
178 List *cteList; /* WITH list (of CommonTableExpr's) */
179
180 List *rtable; /* list of range table entries */
181
182 /*
183 * list of RTEPermissionInfo nodes for the rtable entries having
184 * perminfoindex > 0
185 */
187 FromExpr *jointree; /* table join tree (FROM and WHERE clauses);
188 * also USING clause for MERGE */
189
190 List *mergeActionList; /* list of actions for MERGE (only) */
191
192 /*
193 * rtable index of target relation for MERGE to pull data. Initially, this
194 * is the same as resultRelation, but after query rewriting, if the target
195 * relation is a trigger-updatable view, this is the index of the expanded
196 * view subquery, whereas resultRelation is the index of the target view.
197 */
199
200 /* join condition between source and target for MERGE */
202
203 List *targetList; /* target list (of TargetEntry) */
204
205 /* OVERRIDING clause */
207
208 OnConflictExpr *onConflict; /* ON CONFLICT DO NOTHING/SELECT/UPDATE */
209
210 /*
211 * The following three fields describe the contents of the RETURNING list
212 * for INSERT/UPDATE/DELETE/MERGE. returningOldAlias and returningNewAlias
213 * are the alias names for OLD and NEW, which may be user-supplied values,
214 * the defaults "old" and "new", or NULL (if the default "old"/"new" is
215 * already in use as the alias for some other relation).
216 */
217 char *returningOldAlias pg_node_attr(query_jumble_ignore);
218 char *returningNewAlias pg_node_attr(query_jumble_ignore);
219 List *returningList; /* return-values list (of TargetEntry) */
220
221 List *groupClause; /* a list of SortGroupClause's */
222 bool groupDistinct; /* was GROUP BY DISTINCT used? */
223 bool groupByAll; /* was GROUP BY ALL used? */
224
225 List *groupingSets; /* a list of GroupingSet's if present */
226
227 Node *havingQual; /* qualifications applied to groups */
228
229 List *windowClause; /* a list of WindowClause's */
230
231 List *distinctClause; /* a list of SortGroupClause's */
232
233 List *sortClause; /* a list of SortGroupClause's */
234
235 Node *limitOffset; /* # of result tuples to skip (int8 expr) */
236 Node *limitCount; /* # of result tuples to return (int8 expr) */
237 LimitOption limitOption; /* limit type */
238
239 List *rowMarks; /* a list of RowMarkClause's */
240
241 Node *setOperations; /* set-operation tree if this is top level of
242 * a UNION/INTERSECT/EXCEPT query */
243
244 /*
245 * A list of pg_constraint OIDs that the query depends on to be
246 * semantically valid
247 */
249
250 /* a list of WithCheckOption's (added during rewrite) */
252
253 /*
254 * The following two fields identify the portion of the source text string
255 * containing this query. They are typically only populated in top-level
256 * Queries, not in sub-queries. When not set, they might both be zero, or
257 * both be -1 meaning "unknown".
258 */
259 /* start location, or -1 if unknown */
261 /* length in bytes; 0 means "rest of string" */
264
265
266/****************************************************************************
267 * Supporting data structures for Parse Trees
268 *
269 * Most of these node types appear in raw parsetrees output by the grammar,
270 * and get transformed to something else by the analyzer. A few of them
271 * are used as-is in transformed querytrees.
272 ****************************************************************************/
273
274/*
275 * TypeName - specifies a type in definitions
276 *
277 * For TypeName structures generated internally, it is often easier to
278 * specify the type by OID than by name. If "names" is NIL then the
279 * actual type OID is given by typeOid, otherwise typeOid is unused.
280 * Similarly, if "typmods" is NIL then the actual typmod is expected to
281 * be prespecified in typemod, otherwise typemod is unused.
282 *
283 * If pct_type is true, then names is actually a field name and we look up
284 * the type of that field. Otherwise (the normal case), names is a type
285 * name possibly qualified with schema and database name.
286 */
287typedef struct TypeName
288{
290 List *names; /* qualified name (list of String nodes) */
291 Oid typeOid; /* type identified by OID */
292 bool setof; /* is a set? */
293 bool pct_type; /* %TYPE specified? */
294 List *typmods; /* type modifier expression(s) */
295 int32 typemod; /* prespecified type modifier */
296 List *arrayBounds; /* array bounds */
297 ParseLoc location; /* token location, or -1 if unknown */
299
300/*
301 * ColumnRef - specifies a reference to a column, or possibly a whole tuple
302 *
303 * The "fields" list must be nonempty. It can contain String nodes
304 * (representing names) and A_Star nodes (representing occurrence of a '*').
305 * Currently, A_Star must appear only as the last list element --- the grammar
306 * is responsible for enforcing this!
307 *
308 * Note: any container subscripting or selection of fields from composite columns
309 * is represented by an A_Indirection node above the ColumnRef. However,
310 * for simplicity in the normal case, initial field selection from a table
311 * name is represented within ColumnRef and not by adding A_Indirection.
312 */
313typedef struct ColumnRef
314{
316 List *fields; /* field names (String nodes) or A_Star */
317 ParseLoc location; /* token location, or -1 if unknown */
319
320/*
321 * ParamRef - specifies a $n parameter reference
322 */
323typedef struct ParamRef
324{
326 int number; /* the number of the parameter */
327 ParseLoc location; /* token location, or -1 if unknown */
329
330/*
331 * A_Expr - infix, prefix, and postfix expressions
332 */
333typedef enum A_Expr_Kind
334{
335 AEXPR_OP, /* normal operator */
336 AEXPR_OP_ANY, /* scalar op ANY (array) */
337 AEXPR_OP_ALL, /* scalar op ALL (array) */
338 AEXPR_DISTINCT, /* IS DISTINCT FROM - name must be "=" */
339 AEXPR_NOT_DISTINCT, /* IS NOT DISTINCT FROM - name must be "=" */
340 AEXPR_NULLIF, /* NULLIF - name must be "=" */
341 AEXPR_IN, /* [NOT] IN - name must be "=" or "<>" */
342 AEXPR_LIKE, /* [NOT] LIKE - name must be "~~" or "!~~" */
343 AEXPR_ILIKE, /* [NOT] ILIKE - name must be "~~*" or "!~~*" */
344 AEXPR_SIMILAR, /* [NOT] SIMILAR - name must be "~" or "!~" */
345 AEXPR_BETWEEN, /* name must be "BETWEEN" */
346 AEXPR_NOT_BETWEEN, /* name must be "NOT BETWEEN" */
347 AEXPR_BETWEEN_SYM, /* name must be "BETWEEN SYMMETRIC" */
348 AEXPR_NOT_BETWEEN_SYM, /* name must be "NOT BETWEEN SYMMETRIC" */
350
351typedef struct A_Expr
352{
354
356 A_Expr_Kind kind; /* see above */
357 List *name; /* possibly-qualified name of operator */
358 Node *lexpr; /* left argument, or NULL if none */
359 Node *rexpr; /* right argument, or NULL if none */
360
361 /*
362 * If rexpr is a list of some kind, we separately track its starting and
363 * ending location; it's not the same as the starting and ending location
364 * of the token itself.
365 */
368 ParseLoc location; /* token location, or -1 if unknown */
370
371/*
372 * A_Const - a literal constant
373 *
374 * Value nodes are inline for performance. You can treat 'val' as a node,
375 * as in IsA(&val, Integer). 'val' is not valid if isnull is true.
376 */
386
387typedef struct A_Const
388{
390
393 bool isnull; /* SQL NULL constant */
394 ParseLoc location; /* token location, or -1 if unknown */
396
397/*
398 * TypeCast - a CAST expression
399 */
400typedef struct TypeCast
401{
403 Node *arg; /* the expression being casted */
404 TypeName *typeName; /* the target type */
405 ParseLoc location; /* token location, or -1 if unknown */
407
408/*
409 * CollateClause - a COLLATE expression
410 */
411typedef struct CollateClause
412{
414 Node *arg; /* input expression */
415 List *collname; /* possibly-qualified collation name */
416 ParseLoc location; /* token location, or -1 if unknown */
418
419/*
420 * RoleSpec - a role name or one of a few special values.
421 */
422typedef enum RoleSpecType
423{
424 ROLESPEC_CSTRING, /* role name is stored as a C string */
425 ROLESPEC_CURRENT_ROLE, /* role spec is CURRENT_ROLE */
426 ROLESPEC_CURRENT_USER, /* role spec is CURRENT_USER */
427 ROLESPEC_SESSION_USER, /* role spec is SESSION_USER */
428 ROLESPEC_PUBLIC, /* role name is "public" */
430
431typedef struct RoleSpec
432{
434 RoleSpecType roletype; /* Type of this rolespec */
435 char *rolename; /* filled only for ROLESPEC_CSTRING */
436 ParseLoc location; /* token location, or -1 if unknown */
438
439/*
440 * FuncCall - a function or aggregate invocation
441 *
442 * agg_order (if not NIL) indicates we saw 'foo(... ORDER BY ...)', or if
443 * agg_within_group is true, it was 'foo(...) WITHIN GROUP (ORDER BY ...)'.
444 * agg_star indicates we saw a 'foo(*)' construct, while agg_distinct
445 * indicates we saw 'foo(DISTINCT ...)'. In any of these cases, the
446 * construct *must* be an aggregate call. Otherwise, it might be either an
447 * aggregate or some other kind of function. However, if FILTER or OVER is
448 * present it had better be an aggregate or window function.
449 *
450 * Normally, you'd initialize this via makeFuncCall() and then only change the
451 * parts of the struct its defaults don't match afterwards, as needed.
452 */
453typedef struct FuncCall
454{
456 List *funcname; /* qualified name of function */
457 List *args; /* the arguments (list of exprs) */
458 List *agg_order; /* ORDER BY (list of SortBy) */
459 Node *agg_filter; /* FILTER clause, if any */
460 struct WindowDef *over; /* OVER clause, if any */
461 int ignore_nulls; /* ignore nulls for window function */
462 bool agg_within_group; /* ORDER BY appeared in WITHIN GROUP */
463 bool agg_star; /* argument was really '*' */
464 bool agg_distinct; /* arguments were labeled DISTINCT */
465 bool func_variadic; /* last argument was labeled VARIADIC */
466 CoercionForm funcformat; /* how to display this node */
467 ParseLoc location; /* token location, or -1 if unknown */
469
470/*
471 * A_Star - '*' representing all columns of a table or compound field
472 *
473 * This can appear within ColumnRef.fields, A_Indirection.indirection, and
474 * ResTarget.indirection lists.
475 */
476typedef struct A_Star
477{
480
481/*
482 * A_Indices - array subscript or slice bounds ([idx] or [lidx:uidx])
483 *
484 * In slice case, either or both of lidx and uidx can be NULL (omitted).
485 * In non-slice case, uidx holds the single subscript and lidx is always NULL.
486 */
487typedef struct A_Indices
488{
490 bool is_slice; /* true if slice (i.e., colon present) */
491 Node *lidx; /* slice lower bound, if any */
492 Node *uidx; /* subscript, or slice upper bound if any */
494
495/*
496 * A_Indirection - select a field and/or array element from an expression
497 *
498 * The indirection list can contain A_Indices nodes (representing
499 * subscripting), String nodes (representing field selection --- the
500 * string value is the name of the field to select), and A_Star nodes
501 * (representing selection of all fields of a composite type).
502 * For example, a complex selection operation like
503 * (foo).field1[42][7].field2
504 * would be represented with a single A_Indirection node having a 4-element
505 * indirection list.
506 *
507 * Currently, A_Star must appear only as the last list element --- the grammar
508 * is responsible for enforcing this!
509 */
510typedef struct A_Indirection
511{
513 Node *arg; /* the thing being selected from */
514 List *indirection; /* subscripts and/or field names and/or * */
516
517/*
518 * A_ArrayExpr - an ARRAY[] construct
519 */
520typedef struct A_ArrayExpr
521{
523 List *elements; /* array element expressions */
524 ParseLoc list_start; /* start of the element list */
525 ParseLoc list_end; /* end of the elements list */
526 ParseLoc location; /* token location, or -1 if unknown */
528
529/*
530 * ResTarget -
531 * result target (used in target list of pre-transformed parse trees)
532 *
533 * In a SELECT target list, 'name' is the column label from an
534 * 'AS ColumnLabel' clause, or NULL if there was none, and 'val' is the
535 * value expression itself. The 'indirection' field is not used.
536 *
537 * INSERT uses ResTarget in its target-column-names list. Here, 'name' is
538 * the name of the destination column, 'indirection' stores any subscripts
539 * attached to the destination, and 'val' is not used.
540 *
541 * In an UPDATE target list, 'name' is the name of the destination column,
542 * 'indirection' stores any subscripts attached to the destination, and
543 * 'val' is the expression to assign.
544 *
545 * See A_Indirection for more info about what can appear in 'indirection'.
546 */
547typedef struct ResTarget
548{
550 char *name; /* column name or NULL */
551 List *indirection; /* subscripts, field names, and '*', or NIL */
552 Node *val; /* the value expression to compute or assign */
553 ParseLoc location; /* token location, or -1 if unknown */
555
556/*
557 * MultiAssignRef - element of a row source expression for UPDATE
558 *
559 * In an UPDATE target list, when we have SET (a,b,c) = row-valued-expression,
560 * we generate separate ResTarget items for each of a,b,c. Their "val" trees
561 * are MultiAssignRef nodes numbered 1..n, linking to a common copy of the
562 * row-valued-expression (which parse analysis will process only once, when
563 * handling the MultiAssignRef with colno=1).
564 */
565typedef struct MultiAssignRef
566{
568 Node *source; /* the row-valued expression */
569 int colno; /* column number for this target (1..n) */
570 int ncolumns; /* number of targets in the construct */
572
573/*
574 * SortBy - for ORDER BY clause
575 */
576typedef struct SortBy
577{
579 Node *node; /* expression to sort on */
580 SortByDir sortby_dir; /* ASC/DESC/USING/default */
581 SortByNulls sortby_nulls; /* NULLS FIRST/LAST */
582 List *useOp; /* name of op to use, if SORTBY_USING */
583 ParseLoc location; /* operator location, or -1 if none/unknown */
585
586/*
587 * WindowDef - raw representation of WINDOW and OVER clauses
588 *
589 * For entries in a WINDOW list, "name" is the window name being defined.
590 * For OVER clauses, we use "name" for the "OVER window" syntax, or "refname"
591 * for the "OVER (window)" syntax, which is subtly different --- the latter
592 * implies overriding the window frame clause.
593 */
594typedef struct WindowDef
595{
597 char *name; /* window's own name */
598 char *refname; /* referenced window name, if any */
599 List *partitionClause; /* PARTITION BY expression list */
600 List *orderClause; /* ORDER BY (list of SortBy) */
601 int frameOptions; /* frame_clause options, see below */
602 Node *startOffset; /* expression for starting bound, if any */
603 Node *endOffset; /* expression for ending bound, if any */
604 ParseLoc location; /* parse location, or -1 if none/unknown */
606
607/*
608 * frameOptions is an OR of these bits. The NONDEFAULT and BETWEEN bits are
609 * used so that ruleutils.c can tell which properties were specified and
610 * which were defaulted; the correct behavioral bits must be set either way.
611 * The START_foo and END_foo options must come in pairs of adjacent bits for
612 * the convenience of gram.y, even though some of them are useless/invalid.
613 */
614#define FRAMEOPTION_NONDEFAULT 0x00001 /* any specified? */
615#define FRAMEOPTION_RANGE 0x00002 /* RANGE behavior */
616#define FRAMEOPTION_ROWS 0x00004 /* ROWS behavior */
617#define FRAMEOPTION_GROUPS 0x00008 /* GROUPS behavior */
618#define FRAMEOPTION_BETWEEN 0x00010 /* BETWEEN given? */
619#define FRAMEOPTION_START_UNBOUNDED_PRECEDING 0x00020 /* start is U. P. */
620#define FRAMEOPTION_END_UNBOUNDED_PRECEDING 0x00040 /* (disallowed) */
621#define FRAMEOPTION_START_UNBOUNDED_FOLLOWING 0x00080 /* (disallowed) */
622#define FRAMEOPTION_END_UNBOUNDED_FOLLOWING 0x00100 /* end is U. F. */
623#define FRAMEOPTION_START_CURRENT_ROW 0x00200 /* start is C. R. */
624#define FRAMEOPTION_END_CURRENT_ROW 0x00400 /* end is C. R. */
625#define FRAMEOPTION_START_OFFSET_PRECEDING 0x00800 /* start is O. P. */
626#define FRAMEOPTION_END_OFFSET_PRECEDING 0x01000 /* end is O. P. */
627#define FRAMEOPTION_START_OFFSET_FOLLOWING 0x02000 /* start is O. F. */
628#define FRAMEOPTION_END_OFFSET_FOLLOWING 0x04000 /* end is O. F. */
629#define FRAMEOPTION_EXCLUDE_CURRENT_ROW 0x08000 /* omit C.R. */
630#define FRAMEOPTION_EXCLUDE_GROUP 0x10000 /* omit C.R. & peers */
631#define FRAMEOPTION_EXCLUDE_TIES 0x20000 /* omit C.R.'s peers */
632
633#define FRAMEOPTION_START_OFFSET \
634 (FRAMEOPTION_START_OFFSET_PRECEDING | FRAMEOPTION_START_OFFSET_FOLLOWING)
635#define FRAMEOPTION_END_OFFSET \
636 (FRAMEOPTION_END_OFFSET_PRECEDING | FRAMEOPTION_END_OFFSET_FOLLOWING)
637#define FRAMEOPTION_EXCLUSION \
638 (FRAMEOPTION_EXCLUDE_CURRENT_ROW | FRAMEOPTION_EXCLUDE_GROUP | \
639 FRAMEOPTION_EXCLUDE_TIES)
640
641#define FRAMEOPTION_DEFAULTS \
642 (FRAMEOPTION_RANGE | FRAMEOPTION_START_UNBOUNDED_PRECEDING | \
643 FRAMEOPTION_END_CURRENT_ROW)
644
645/*
646 * RangeSubselect - subquery appearing in a FROM clause
647 */
648typedef struct RangeSubselect
649{
651 bool lateral; /* does it have LATERAL prefix? */
652 Node *subquery; /* the untransformed sub-select clause */
653 Alias *alias; /* table alias & optional column aliases */
655
656/*
657 * RangeFunction - function call appearing in a FROM clause
658 *
659 * functions is a List because we use this to represent the construct
660 * ROWS FROM(func1(...), func2(...), ...). Each element of this list is a
661 * two-element sublist, the first element being the untransformed function
662 * call tree, and the second element being a possibly-empty list of ColumnDef
663 * nodes representing any columndef list attached to that function within the
664 * ROWS FROM() syntax.
665 *
666 * alias and coldeflist represent any alias and/or columndef list attached
667 * at the top level. (We disallow coldeflist appearing both here and
668 * per-function, but that's checked in parse analysis, not by the grammar.)
669 */
670typedef struct RangeFunction
671{
673 bool lateral; /* does it have LATERAL prefix? */
674 bool ordinality; /* does it have WITH ORDINALITY suffix? */
675 bool is_rowsfrom; /* is result of ROWS FROM() syntax? */
676 List *functions; /* per-function information, see above */
677 Alias *alias; /* table alias & optional column aliases */
678 List *coldeflist; /* list of ColumnDef nodes to describe result
679 * of function returning RECORD */
681
682/*
683 * RangeTableFunc - raw form of "table functions" such as XMLTABLE
684 *
685 * Note: JSON_TABLE is also a "table function", but it uses JsonTable node,
686 * not RangeTableFunc.
687 */
688typedef struct RangeTableFunc
689{
691 bool lateral; /* does it have LATERAL prefix? */
692 Node *docexpr; /* document expression */
693 Node *rowexpr; /* row generator expression */
694 List *namespaces; /* list of namespaces as ResTarget */
695 List *columns; /* list of RangeTableFuncCol */
696 Alias *alias; /* table alias & optional column aliases */
697 ParseLoc location; /* token location, or -1 if unknown */
699
700/*
701 * RangeTableFuncCol - one column in a RangeTableFunc->columns
702 *
703 * If for_ordinality is true (FOR ORDINALITY), then the column is an int4
704 * column and the rest of the fields are ignored.
705 */
706typedef struct RangeTableFuncCol
707{
709 char *colname; /* name of generated column */
710 TypeName *typeName; /* type of generated column */
711 bool for_ordinality; /* does it have FOR ORDINALITY? */
712 bool is_not_null; /* does it have NOT NULL? */
713 Node *colexpr; /* column filter expression */
714 Node *coldefexpr; /* column default value expression */
715 ParseLoc location; /* token location, or -1 if unknown */
717
718/*
719 * RangeGraphTable - raw form of GRAPH_TABLE clause
720 */
721typedef struct RangeGraphTable
722{
727 Alias *alias; /* table alias & optional column aliases */
728 ParseLoc location; /* token location, or -1 if unknown */
730
731/*
732 * RangeTableSample - TABLESAMPLE appearing in a raw FROM clause
733 *
734 * This node, appearing only in raw parse trees, represents
735 * <relation> TABLESAMPLE <method> (<params>) REPEATABLE (<num>)
736 * Currently, the <relation> can only be a RangeVar, but we might in future
737 * allow RangeSubselect and other options. Note that the RangeTableSample
738 * is wrapped around the node representing the <relation>, rather than being
739 * a subfield of it.
740 */
741typedef struct RangeTableSample
742{
744 Node *relation; /* relation to be sampled */
745 List *method; /* sampling method name (possibly qualified) */
746 List *args; /* argument(s) for sampling method */
747 Node *repeatable; /* REPEATABLE expression, or NULL if none */
748 ParseLoc location; /* method name location, or -1 if unknown */
750
751/*
752 * ColumnDef - column definition (used in various creates)
753 *
754 * If the column has a default value, we may have the value expression
755 * in either "raw" form (an untransformed parse tree) or "cooked" form
756 * (a post-parse-analysis, executable expression tree), depending on
757 * how this ColumnDef node was created (by parsing, or by inheritance
758 * from an existing relation). We should never have both in the same node!
759 *
760 * Similarly, we may have a COLLATE specification in either raw form
761 * (represented as a CollateClause with arg==NULL) or cooked form
762 * (the collation's OID).
763 *
764 * The constraints list may contain a CONSTR_DEFAULT item in a raw
765 * parsetree produced by gram.y, but transformCreateStmt will remove
766 * the item and set raw_default instead. CONSTR_DEFAULT items
767 * should not appear in any subsequent processing.
768 */
769typedef struct ColumnDef
770{
772 char *colname; /* name of column */
773 TypeName *typeName; /* type of column */
774 char *compression; /* compression method for column */
775 int16 inhcount; /* number of times column is inherited */
776 bool is_local; /* column has local (non-inherited) def'n */
777 bool is_not_null; /* NOT NULL constraint specified? */
778 bool is_from_type; /* column definition came from table type */
779 char storage; /* attstorage setting, or 0 for default */
780 char *storage_name; /* attstorage setting name or NULL for default */
781 Node *raw_default; /* default value (untransformed parse tree) */
782 Node *cooked_default; /* default value (transformed expr tree) */
783 char identity; /* attidentity setting */
784 RangeVar *identitySequence; /* to store identity sequence name for
785 * ALTER TABLE ... ADD COLUMN */
786 char generated; /* attgenerated setting */
787 CollateClause *collClause; /* untransformed COLLATE spec, if any */
788 Oid collOid; /* collation OID (InvalidOid if not set) */
789 List *constraints; /* other constraints on column */
790 List *fdwoptions; /* per-column FDW options */
791 ParseLoc location; /* parse location, or -1 if none/unknown */
793
794/*
795 * TableLikeClause - CREATE TABLE ( ... LIKE ... ) clause
796 */
797typedef struct TableLikeClause
798{
801 uint32 options; /* OR of TableLikeOption flags */
802 Oid relationOid; /* If table has been looked up, its OID */
804
818
819/*
820 * IndexElem - index parameters (used in CREATE INDEX, and in ON CONFLICT)
821 *
822 * For a plain index attribute, 'name' is the name of the table column to
823 * index, and 'expr' is NULL. For an index expression, 'name' is NULL and
824 * 'expr' is the expression tree.
825 */
826typedef struct IndexElem
827{
829 char *name; /* name of attribute to index, or NULL */
830 Node *expr; /* expression to index, or NULL */
831 char *indexcolname; /* name for index column; NULL = default */
832 List *collation; /* name of collation; NIL = default */
833 List *opclass; /* name of desired opclass; NIL = default */
834 List *opclassopts; /* opclass-specific options, or NIL */
835 SortByDir ordering; /* ASC/DESC/default */
836 SortByNulls nulls_ordering; /* FIRST/LAST/default */
837 ParseLoc location; /* token location, or -1 if unknown */
839
840/*
841 * DefElem - a generic "name = value" option definition
842 *
843 * In some contexts the name can be qualified. Also, certain SQL commands
844 * allow a SET/ADD/DROP action to be attached to option settings, so it's
845 * convenient to carry a field for that too. (Note: currently, it is our
846 * practice that the grammar allows namespace and action only in statements
847 * where they are relevant; C code can just ignore those fields in other
848 * statements.)
849 */
857
858typedef struct DefElem
859{
861 char *defnamespace; /* NULL if unqualified name */
862 char *defname;
863 Node *arg; /* typically Integer, Float, String, or
864 * TypeName */
865 DefElemAction defaction; /* unspecified action, or SET/ADD/DROP */
866 ParseLoc location; /* token location, or -1 if unknown */
868
869/*
870 * LockingClause - raw representation of FOR [NO KEY] UPDATE/[KEY] SHARE
871 * options
872 *
873 * Note: lockedRels == NIL means "all relations in query". Otherwise it
874 * is a list of RangeVar nodes. (We use RangeVar mainly because it carries
875 * a location field --- currently, parse analysis insists on unqualified
876 * names in LockingClause.)
877 */
878typedef struct LockingClause
879{
881 List *lockedRels; /* FOR [KEY] UPDATE/SHARE relations */
883 LockWaitPolicy waitPolicy; /* NOWAIT and SKIP LOCKED */
885
886/*
887 * XMLSERIALIZE (in raw parse tree only)
888 */
889typedef struct XmlSerialize
890{
892 XmlOptionType xmloption; /* DOCUMENT or CONTENT */
895 bool indent; /* [NO] INDENT */
896 ParseLoc location; /* token location, or -1 if unknown */
898
899/* Partitioning related definitions */
900
901/*
902 * PartitionElem - parse-time representation of a single partition key
903 *
904 * expr can be either a raw expression tree or a parse-analyzed expression.
905 * We don't store these on-disk, though.
906 */
907typedef struct PartitionElem
908{
910 char *name; /* name of column to partition on, or NULL */
911 Node *expr; /* expression to partition on, or NULL */
912 List *collation; /* name of collation; NIL = default */
913 List *opclass; /* name of desired opclass; NIL = default */
914 ParseLoc location; /* token location, or -1 if unknown */
916
923
924/*
925 * PartitionSpec - parse-time representation of a partition key specification
926 *
927 * This represents the key space we will be partitioning on.
928 */
929typedef struct PartitionSpec
930{
933 List *partParams; /* List of PartitionElems */
934 ParseLoc location; /* token location, or -1 if unknown */
936
937/*
938 * PartitionBoundSpec - a partition bound specification
939 *
940 * This represents the portion of the partition key space assigned to a
941 * particular partition. These are stored on disk in pg_class.relpartbound.
942 */
944{
946
947 char strategy; /* see PARTITION_STRATEGY codes above */
948 bool is_default; /* is it a default partition bound? */
949
950 /* Partitioning info for HASH strategy: */
953
954 /* Partitioning info for LIST strategy: */
955 List *listdatums; /* List of Consts (or A_Consts in raw tree) */
956
957 /* Partitioning info for RANGE strategy: */
958 List *lowerdatums; /* List of PartitionRangeDatums */
959 List *upperdatums; /* List of PartitionRangeDatums */
960
961 ParseLoc location; /* token location, or -1 if unknown */
962};
963
964/*
965 * PartitionRangeDatum - one of the values in a range partition bound
966 *
967 * This can be MINVALUE, MAXVALUE or a specific bounded value.
968 */
970{
971 PARTITION_RANGE_DATUM_MINVALUE = -1, /* less than any other value */
972 PARTITION_RANGE_DATUM_VALUE = 0, /* a specific (bounded) value */
973 PARTITION_RANGE_DATUM_MAXVALUE = 1, /* greater than any other value */
975
977{
979
981 Node *value; /* Const (or A_Const in raw tree), if kind is
982 * PARTITION_RANGE_DATUM_VALUE, else NULL */
983
984 ParseLoc location; /* token location, or -1 if unknown */
986
987/*
988 * PartitionDesc - info about a single partition for the ALTER TABLE SPLIT
989 * PARTITION command
990 */
992{
994
995 RangeVar *name; /* name of partition */
996 PartitionBoundSpec *bound; /* FOR VALUES, if attaching */
998
999/*
1000 * PartitionCmd - info for ALTER TABLE/INDEX ATTACH/DETACH PARTITION and for
1001 * ALTER TABLE SPLIT/MERGE PARTITION(S) commands
1002 */
1003typedef struct PartitionCmd
1004{
1006
1007 /* name of partition to attach/detach/merge/split */
1009
1010 /* FOR VALUES, if attaching */
1012
1013 /*
1014 * list of partitions to be split/merged, used in ALTER TABLE MERGE
1015 * PARTITIONS and ALTER TABLE SPLIT PARTITIONS. For merge partitions,
1016 * partlist is a list of RangeVar; For split partition, it is a list of
1017 * SinglePartitionSpec.
1018 */
1020
1023
1024/*
1025 * Nodes for graph pattern
1026 */
1027
1034
1043
1044#define IS_EDGE_PATTERN(kind) ((kind) == EDGE_PATTERN_ANY || \
1045 (kind) == EDGE_PATTERN_RIGHT || \
1046 (kind) == EDGE_PATTERN_LEFT)
1047
1059
1060/****************************************************************************
1061 * Nodes for a Query tree
1062 ****************************************************************************/
1063
1064/*--------------------
1065 * RangeTblEntry -
1066 * A range table is a List of RangeTblEntry nodes.
1067 *
1068 * A range table entry may represent a plain relation, a sub-select in
1069 * FROM, or the result of a JOIN clause. (Only explicit JOIN syntax
1070 * produces an RTE, not the implicit join resulting from multiple FROM
1071 * items. This is because we only need the RTE to deal with SQL features
1072 * like outer joins and join-output-column aliasing.) Other special
1073 * RTE types also exist, as indicated by RTEKind.
1074 *
1075 * Note that we consider RTE_RELATION to cover anything that has a pg_class
1076 * entry. relkind distinguishes the sub-cases.
1077 *
1078 * alias is an Alias node representing the AS alias-clause attached to the
1079 * FROM expression, or NULL if no clause.
1080 *
1081 * eref is the table reference name and column reference names (either
1082 * real or aliases). Note that system columns (OID etc) are not included
1083 * in the column list.
1084 * eref->aliasname is required to be present, and should generally be used
1085 * to identify the RTE for error messages etc.
1086 *
1087 * In RELATION RTEs, the colnames in both alias and eref are indexed by
1088 * physical attribute number; this means there must be colname entries for
1089 * dropped columns. When building an RTE we insert empty strings ("") for
1090 * dropped columns. Note however that a stored rule may have nonempty
1091 * colnames for columns dropped since the rule was created (and for that
1092 * matter the colnames might be out of date due to column renamings).
1093 * The same comments apply to FUNCTION RTEs when a function's return type
1094 * is a named composite type.
1095 *
1096 * In JOIN RTEs, the colnames in both alias and eref are one-to-one with
1097 * joinaliasvars entries. A JOIN RTE will omit columns of its inputs when
1098 * those columns are known to be dropped at parse time. Again, however,
1099 * a stored rule might contain entries for columns dropped since the rule
1100 * was created. (This is only possible for columns not actually referenced
1101 * in the rule.) When loading a stored rule, we replace the joinaliasvars
1102 * items for any such columns with null pointers. (We can't simply delete
1103 * them from the joinaliasvars list, because that would affect the attnums
1104 * of Vars referencing the rest of the list.)
1105 *
1106 * inFromCl marks those range variables that are listed in the FROM clause.
1107 * It's false for RTEs that are added to a query behind the scenes, such
1108 * as the NEW and OLD variables for a rule, or the subqueries of a UNION.
1109 * This flag is not used during parsing (except in transformLockingClause,
1110 * q.v.); the parser now uses a separate "namespace" data structure to
1111 * control visibility. But it is needed by ruleutils.c to determine
1112 * whether RTEs should be shown in decompiled queries.
1113 *
1114 * securityQuals is a list of security barrier quals (boolean expressions),
1115 * to be tested in the listed order before returning a row from the
1116 * relation. It is always NIL in parser output. Entries are added by the
1117 * rewriter to implement security-barrier views and/or row-level security.
1118 * Note that the planner turns each boolean expression into an implicitly
1119 * AND'ed sublist, as is its usual habit with qualification expressions.
1120 *--------------------
1121 */
1122typedef enum RTEKind
1123{
1124 RTE_RELATION, /* ordinary relation reference */
1125 RTE_SUBQUERY, /* subquery in FROM */
1126 RTE_JOIN, /* join */
1127 RTE_FUNCTION, /* function in FROM */
1128 RTE_TABLEFUNC, /* TableFunc(.., column list) */
1129 RTE_VALUES, /* VALUES (<exprlist>), (<exprlist>), ... */
1130 RTE_CTE, /* common table expr (WITH list element) */
1131 RTE_NAMEDTUPLESTORE, /* tuplestore, e.g. for AFTER triggers */
1132 RTE_GRAPH_TABLE, /* GRAPH_TABLE clause */
1133 RTE_RESULT, /* RTE represents an empty FROM clause; such
1134 * RTEs are added by the planner, they're not
1135 * present during parsing or rewriting */
1136 RTE_GROUP, /* the grouping step */
1138
1139typedef struct RangeTblEntry
1140{
1142
1143 NodeTag type;
1144
1145 /*
1146 * Fields valid in all RTEs:
1147 *
1148 * put alias + eref first to make dump more legible
1149 */
1150 /* user-written alias clause, if any */
1152
1153 /*
1154 * Expanded reference names. This uses a custom query jumble function so
1155 * that the table name is included in the computation, but not its list of
1156 * columns.
1157 */
1159
1160 RTEKind rtekind; /* see above */
1161
1162 /*
1163 * Fields valid for a plain relation RTE (else zero):
1164 *
1165 * inh is true for relation references that should be expanded to include
1166 * inheritance children, if the rel has any. In the parser, this will
1167 * only be true for RTE_RELATION entries. The planner also uses this
1168 * field to mark RTE_SUBQUERY entries that contain UNION ALL queries that
1169 * it has flattened into pulled-up subqueries (creating a structure much
1170 * like the effects of inheritance).
1171 *
1172 * rellockmode is really LOCKMODE, but it's declared int to avoid having
1173 * to include lock-related headers here. It must be RowExclusiveLock if
1174 * the RTE is an INSERT/UPDATE/DELETE/MERGE target, else RowShareLock if
1175 * the RTE is a SELECT FOR UPDATE/FOR SHARE target, else AccessShareLock.
1176 *
1177 * Note: in some cases, rule expansion may result in RTEs that are marked
1178 * with RowExclusiveLock even though they are not the target of the
1179 * current query; this happens if a DO ALSO rule simply scans the original
1180 * target table. We leave such RTEs with their original lockmode so as to
1181 * avoid getting an additional, lesser lock.
1182 *
1183 * perminfoindex is 1-based index of the RTEPermissionInfo belonging to
1184 * this RTE in the containing struct's list of same; 0 if permissions need
1185 * not be checked for this RTE.
1186 *
1187 * As a special case, relid, relkind, rellockmode, and perminfoindex can
1188 * also be set (nonzero) in an RTE_SUBQUERY RTE. This occurs when we
1189 * convert an RTE_RELATION RTE naming a view into an RTE_SUBQUERY
1190 * containing the view's query. We still need to perform run-time locking
1191 * and permission checks on the view, even though it's not directly used
1192 * in the query anymore, and the most expedient way to do that is to
1193 * retain these fields from the old state of the RTE.
1194 *
1195 * As a special case, RTE_NAMEDTUPLESTORE can also set relid to indicate
1196 * that the tuple format of the tuplestore is the same as the referenced
1197 * relation. This allows plans referencing AFTER trigger transition
1198 * tables to be invalidated if the underlying table is altered.
1199 */
1200 /* OID of the relation */
1202 /* inheritance requested? */
1203 bool inh;
1204 /* relation kind (see pg_class.relkind) */
1206 /* lock level that query requires on the rel */
1208 /* index of RTEPermissionInfo entry, or 0 */
1210 /* sampling info, or NULL */
1212
1213 /*
1214 * Fields valid for a subquery RTE (else NULL):
1215 */
1216 /* the sub-query */
1218 /* is from security_barrier view? */
1219 bool security_barrier pg_node_attr(query_jumble_ignore);
1220
1221 /*
1222 * Fields valid for a join RTE (else NULL/zero):
1223 *
1224 * joinaliasvars is a list of (usually) Vars corresponding to the columns
1225 * of the join result. An alias Var referencing column K of the join
1226 * result can be replaced by the K'th element of joinaliasvars --- but to
1227 * simplify the task of reverse-listing aliases correctly, we do not do
1228 * that until planning time. In detail: an element of joinaliasvars can
1229 * be a Var of one of the join's input relations, or such a Var with an
1230 * implicit coercion to the join's output column type, or a COALESCE
1231 * expression containing the two input column Vars (possibly coerced).
1232 * Elements beyond the first joinmergedcols entries are always just Vars,
1233 * and are never referenced from elsewhere in the query (that is, join
1234 * alias Vars are generated only for merged columns). We keep these
1235 * entries only because they're needed in expandRTE() and similar code.
1236 *
1237 * Vars appearing within joinaliasvars are marked with varnullingrels sets
1238 * that describe the nulling effects of this join and lower ones. This is
1239 * essential for FULL JOIN cases, because the COALESCE expression only
1240 * describes the semantics correctly if its inputs have been nulled by the
1241 * join. For other cases, it allows expandRTE() to generate a valid
1242 * representation of the join's output without consulting additional
1243 * parser state.
1244 *
1245 * Within a Query loaded from a stored rule, it is possible for non-merged
1246 * joinaliasvars items to be null pointers, which are placeholders for
1247 * (necessarily unreferenced) columns dropped since the rule was made.
1248 * Also, once planning begins, joinaliasvars items can be almost anything,
1249 * as a result of subquery-flattening substitutions.
1250 *
1251 * joinleftcols is an integer list of physical column numbers of the left
1252 * join input rel that are included in the join; likewise joinrighttcols
1253 * for the right join input rel. (Which rels those are can be determined
1254 * from the associated JoinExpr.) If the join is USING/NATURAL, then the
1255 * first joinmergedcols entries in each list identify the merged columns.
1256 * The merged columns come first in the join output, then remaining
1257 * columns of the left input, then remaining columns of the right.
1258 *
1259 * Note that input columns could have been dropped after creation of a
1260 * stored rule, if they are not referenced in the query (in particular,
1261 * merged columns could not be dropped); this is not accounted for in
1262 * joinleftcols/joinrighttcols.
1263 */
1265 /* number of merged (JOIN USING) columns */
1267 /* list of alias-var expansions */
1269 /* left-side input column numbers */
1271 /* right-side input column numbers */
1273
1274 /*
1275 * join_using_alias is an alias clause attached directly to JOIN/USING. It
1276 * is different from the alias field (above) in that it does not hide the
1277 * range variables of the tables being joined.
1278 */
1280
1281 /*
1282 * Fields valid for a function RTE (else NIL/zero):
1283 *
1284 * When funcordinality is true, the eref->colnames list includes an alias
1285 * for the ordinality column. The ordinality column is otherwise
1286 * implicit, and must be accounted for "by hand" in places such as
1287 * expandRTE().
1288 */
1289 /* list of RangeTblFunction nodes */
1291 /* is this called WITH ORDINALITY? */
1293
1294 /*
1295 * Fields valid for a TableFunc RTE (else NULL):
1296 */
1298
1299 /*
1300 * Fields valid for a graph table RTE (else NULL):
1301 */
1304
1305 /*
1306 * Fields valid for a values RTE (else NIL):
1307 */
1308 /* list of expression lists */
1310
1311 /*
1312 * Fields valid for a CTE RTE (else NULL/zero):
1313 */
1314 /* name of the WITH list item */
1315 char *ctename;
1316 /* number of query levels up */
1318 /* is this a recursive self-reference? */
1320
1321 /*
1322 * Fields valid for CTE, VALUES, ENR, and TableFunc RTEs (else NIL):
1323 *
1324 * We need these for CTE RTEs so that the types of self-referential
1325 * columns are well-defined. For VALUES RTEs, storing these explicitly
1326 * saves having to re-determine the info by scanning the values_lists. For
1327 * ENRs, we store the types explicitly here (we could get the information
1328 * from the catalogs if 'relid' was supplied, but we'd still need these
1329 * for TupleDesc-based ENRs, so we might as well always store the type
1330 * info here). For TableFuncs, these fields are redundant with data in
1331 * the TableFunc node, but keeping them here allows some code sharing with
1332 * the other cases.
1333 *
1334 * For ENRs only, we have to consider the possibility of dropped columns.
1335 * A dropped column is included in these lists, but it will have zeroes in
1336 * all three lists (as well as an empty-string entry in eref). Testing
1337 * for zero coltype is the standard way to detect a dropped column.
1338 */
1339 /* OID list of column type OIDs */
1341 /* integer list of column typmods */
1343 /* OID list of column collation OIDs */
1345
1346 /*
1347 * Fields valid for ENR RTEs (else NULL/zero):
1348 */
1349 /* name of ephemeral named relation */
1350 char *enrname;
1351 /* estimated or actual from caller */
1353
1354 /*
1355 * Fields valid for a GROUP RTE (else NIL):
1356 */
1357 /* list of grouping expressions */
1359
1360 /*
1361 * Fields valid in all RTEs:
1362 */
1363 /* was LATERAL specified? */
1365 /* present in FROM clause? */
1367 /* security barrier quals to apply, if any */
1370
1371/*
1372 * RTEPermissionInfo
1373 * Per-relation information for permission checking. Added to the Query
1374 * node by the parser when adding the corresponding RTE to the query
1375 * range table and subsequently editorialized on by the rewriter if
1376 * needed after rule expansion.
1377 *
1378 * Only the relations directly mentioned in the query are checked for
1379 * access permissions by the core executor, so only their RTEPermissionInfos
1380 * are present in the Query. However, extensions may want to check inheritance
1381 * children too, depending on the value of rte->inh, so it's copied in 'inh'
1382 * for their perusal.
1383 *
1384 * requiredPerms and checkAsUser specify run-time access permissions checks
1385 * to be performed at query startup. The user must have *all* of the
1386 * permissions that are OR'd together in requiredPerms (never 0!). If
1387 * checkAsUser is not zero, then do the permissions checks using the access
1388 * rights of that user, not the current effective user ID. (This allows rules
1389 * to act as setuid gateways.)
1390 *
1391 * For SELECT/INSERT/UPDATE permissions, if the user doesn't have table-wide
1392 * permissions then it is sufficient to have the permissions on all columns
1393 * identified in selectedCols (for SELECT) and/or insertedCols and/or
1394 * updatedCols (INSERT with ON CONFLICT DO UPDATE may have all 3).
1395 * selectedCols, insertedCols and updatedCols are bitmapsets, which cannot have
1396 * negative integer members, so we subtract FirstLowInvalidHeapAttributeNumber
1397 * from column numbers before storing them in these fields. A whole-row Var
1398 * reference is represented by setting the bit for InvalidAttrNumber.
1399 *
1400 * updatedCols is also used in some other places, for example, to determine
1401 * which triggers to fire and in FDWs to know which changed columns they need
1402 * to ship off.
1403 */
1404typedef struct RTEPermissionInfo
1405{
1407
1408 Oid relid; /* relation OID */
1409 bool inh; /* separately check inheritance children? */
1410 AclMode requiredPerms; /* bitmask of required access permissions */
1411 Oid checkAsUser; /* if valid, check access as this role */
1412 Bitmapset *selectedCols; /* columns needing SELECT permission */
1413 Bitmapset *insertedCols; /* columns needing INSERT permission */
1414 Bitmapset *updatedCols; /* columns needing UPDATE permission */
1416
1417/*
1418 * RangeTblFunction -
1419 * RangeTblEntry subsidiary data for one function in a FUNCTION RTE.
1420 *
1421 * If the function had a column definition list (required for an
1422 * otherwise-unspecified RECORD result), funccolnames lists the names given
1423 * in the definition list, funccoltypes lists their declared column types,
1424 * funccoltypmods lists their typmods, funccolcollations their collations.
1425 * Otherwise, those fields are NIL.
1426 *
1427 * Notice we don't attempt to store info about the results of functions
1428 * returning named composite types, because those can change from time to
1429 * time. We do however remember how many columns we thought the type had
1430 * (including dropped columns!), so that we can successfully ignore any
1431 * columns added after the query was parsed.
1432 */
1433typedef struct RangeTblFunction
1434{
1436
1437 Node *funcexpr; /* expression tree for func call */
1438 /* number of columns it contributes to RTE */
1440 /* These fields record the contents of a column definition list, if any: */
1441 /* column names (list of String) */
1443 /* OID list of column type OIDs */
1445 /* integer list of column typmods */
1447 /* OID list of column collation OIDs */
1449
1450 /* This is set during planning for use by the executor: */
1451 /* PARAM_EXEC Param IDs affecting this func */
1454
1455/*
1456 * TableSampleClause - TABLESAMPLE appearing in a transformed FROM clause
1457 *
1458 * Unlike RangeTableSample, this is a subnode of the relevant RangeTblEntry.
1459 */
1460typedef struct TableSampleClause
1461{
1463 Oid tsmhandler; /* OID of the tablesample handler function */
1464 List *args; /* tablesample argument expression(s) */
1465 Expr *repeatable; /* REPEATABLE expression, or NULL if none */
1467
1468/*
1469 * WithCheckOption -
1470 * representation of WITH CHECK OPTION checks to be applied to new tuples
1471 * when inserting/updating an auto-updatable view, or RLS WITH CHECK
1472 * policies to be applied when inserting/updating a relation with RLS.
1473 */
1474typedef enum WCOKind
1475{
1476 WCO_VIEW_CHECK, /* WCO on an auto-updatable view */
1477 WCO_RLS_INSERT_CHECK, /* RLS INSERT WITH CHECK policy */
1478 WCO_RLS_UPDATE_CHECK, /* RLS UPDATE WITH CHECK policy */
1479 WCO_RLS_CONFLICT_CHECK, /* RLS ON CONFLICT DO SELECT/UPDATE USING
1480 * policy */
1481 WCO_RLS_MERGE_UPDATE_CHECK, /* RLS MERGE UPDATE USING policy */
1482 WCO_RLS_MERGE_DELETE_CHECK, /* RLS MERGE DELETE USING policy */
1484
1485typedef struct WithCheckOption
1486{
1488 WCOKind kind; /* kind of WCO */
1489 char *relname; /* name of relation that specified the WCO */
1490 char *polname; /* name of RLS policy being checked */
1491 Node *qual; /* constraint qual to check */
1492 bool cascaded; /* true for a cascaded WCO on a view */
1494
1495/*
1496 * SortGroupClause -
1497 * representation of ORDER BY, GROUP BY, PARTITION BY,
1498 * DISTINCT, DISTINCT ON items
1499 *
1500 * You might think that ORDER BY is only interested in defining ordering,
1501 * and GROUP/DISTINCT are only interested in defining equality. However,
1502 * one way to implement grouping is to sort and then apply a "uniq"-like
1503 * filter. So it's also interesting to keep track of possible sort operators
1504 * for GROUP/DISTINCT, and in particular to try to sort for the grouping
1505 * in a way that will also yield a requested ORDER BY ordering. So we need
1506 * to be able to compare ORDER BY and GROUP/DISTINCT lists, which motivates
1507 * the decision to give them the same representation.
1508 *
1509 * tleSortGroupRef must match ressortgroupref of exactly one entry of the
1510 * query's targetlist; that is the expression to be sorted or grouped by.
1511 * eqop is the OID of the equality operator.
1512 * sortop is the OID of the ordering operator (a "<" or ">" operator),
1513 * or InvalidOid if not available.
1514 * nulls_first means about what you'd expect. If sortop is InvalidOid
1515 * then nulls_first is meaningless and should be set to false.
1516 * hashable is true if eqop is hashable (note this condition also depends
1517 * on the datatype of the input expression).
1518 *
1519 * In an ORDER BY item, all fields must be valid. (The eqop isn't essential
1520 * here, but it's cheap to get it along with the sortop, and requiring it
1521 * to be valid eases comparisons to grouping items.) Note that this isn't
1522 * actually enough information to determine an ordering: if the sortop is
1523 * collation-sensitive, a collation OID is needed too. We don't store the
1524 * collation in SortGroupClause because it's not available at the time the
1525 * parser builds the SortGroupClause; instead, consult the exposed collation
1526 * of the referenced targetlist expression to find out what it is.
1527 *
1528 * In a grouping item, eqop must be valid. If the eqop is a btree equality
1529 * operator, then sortop should be set to a compatible ordering operator.
1530 * We prefer to set eqop/sortop/nulls_first to match any ORDER BY item that
1531 * the query presents for the same tlist item. If there is none, we just
1532 * use the default ordering op for the datatype.
1533 *
1534 * If the tlist item's type has a hash opclass but no btree opclass, then
1535 * we will set eqop to the hash equality operator, sortop to InvalidOid,
1536 * and nulls_first to false. A grouping item of this kind can only be
1537 * implemented by hashing, and of course it'll never match an ORDER BY item.
1538 *
1539 * The hashable flag is provided since we generally have the requisite
1540 * information readily available when the SortGroupClause is constructed,
1541 * and it's relatively expensive to get it again later. Note there is no
1542 * need for a "sortable" flag since OidIsValid(sortop) serves the purpose.
1543 *
1544 * A query might have both ORDER BY and DISTINCT (or DISTINCT ON) clauses.
1545 * In SELECT DISTINCT, the distinctClause list is as long or longer than the
1546 * sortClause list, while in SELECT DISTINCT ON it's typically shorter.
1547 * The two lists must match up to the end of the shorter one --- the parser
1548 * rearranges the distinctClause if necessary to make this true. (This
1549 * restriction ensures that only one sort step is needed to both satisfy the
1550 * ORDER BY and set up for the Unique step. This is semantically necessary
1551 * for DISTINCT ON, and presents no real drawback for DISTINCT.)
1552 */
1553typedef struct SortGroupClause
1554{
1556 Index tleSortGroupRef; /* reference into targetlist */
1557 Oid eqop; /* the equality operator ('=' op) */
1558 Oid sortop; /* the ordering operator ('<' op), or 0 */
1559 bool reverse_sort; /* is sortop a "greater than" operator? */
1560 bool nulls_first; /* do NULLs come before normal values? */
1561 /* can eqop be implemented by hashing? */
1564
1565/*
1566 * GroupingSet -
1567 * representation of CUBE, ROLLUP and GROUPING SETS clauses
1568 *
1569 * In a Query with grouping sets, the groupClause contains a flat list of
1570 * SortGroupClause nodes for each distinct expression used. The actual
1571 * structure of the GROUP BY clause is given by the groupingSets tree.
1572 *
1573 * In the raw parser output, GroupingSet nodes (of all types except SIMPLE
1574 * which is not used) are potentially mixed in with the expressions in the
1575 * groupClause of the SelectStmt. (An expression can't contain a GroupingSet,
1576 * but a list may mix GroupingSet and expression nodes.) At this stage, the
1577 * content of each node is a list of expressions, some of which may be RowExprs
1578 * which represent sublists rather than actual row constructors, and nested
1579 * GroupingSet nodes where legal in the grammar. The structure directly
1580 * reflects the query syntax.
1581 *
1582 * In parse analysis, the transformed expressions are used to build the tlist
1583 * and groupClause list (of SortGroupClause nodes), and the groupingSets tree
1584 * is eventually reduced to a fixed format:
1585 *
1586 * EMPTY nodes represent (), and obviously have no content
1587 *
1588 * SIMPLE nodes represent a list of one or more expressions to be treated as an
1589 * atom by the enclosing structure; the content is an integer list of
1590 * ressortgroupref values (see SortGroupClause)
1591 *
1592 * CUBE and ROLLUP nodes contain a list of one or more SIMPLE nodes.
1593 *
1594 * SETS nodes contain a list of EMPTY, SIMPLE, CUBE or ROLLUP nodes, but after
1595 * parse analysis they cannot contain more SETS nodes; enough of the syntactic
1596 * transforms of the spec have been applied that we no longer have arbitrarily
1597 * deep nesting (though we still preserve the use of cube/rollup).
1598 *
1599 * Note that if the groupingSets tree contains no SIMPLE nodes (only EMPTY
1600 * nodes at the leaves), then the groupClause will be empty, but this is still
1601 * an aggregation query (similar to using aggs or HAVING without GROUP BY).
1602 *
1603 * As an example, the following clause:
1604 *
1605 * GROUP BY GROUPING SETS ((a,b), CUBE(c,(d,e)))
1606 *
1607 * looks like this after raw parsing:
1608 *
1609 * SETS( RowExpr(a,b) , CUBE( c, RowExpr(d,e) ) )
1610 *
1611 * and parse analysis converts it to:
1612 *
1613 * SETS( SIMPLE(1,2), CUBE( SIMPLE(3), SIMPLE(4,5) ) )
1614 */
1623
1631
1632/*
1633 * WindowClause -
1634 * transformed representation of WINDOW and OVER clauses
1635 *
1636 * A parsed Query's windowClause list contains these structs. "name" is set
1637 * if the clause originally came from WINDOW, and is NULL if it originally
1638 * was an OVER clause (but note that we collapse out duplicate OVERs).
1639 * partitionClause and orderClause are lists of SortGroupClause structs.
1640 * partitionClause is sanitized by the query planner to remove any columns or
1641 * expressions belonging to redundant PathKeys.
1642 * If we have RANGE with offset PRECEDING/FOLLOWING, the semantics of that are
1643 * specified by startInRangeFunc/inRangeColl/inRangeAsc/inRangeNullsFirst
1644 * for the start offset, or endInRangeFunc/inRange* for the end offset.
1645 * winref is an ID number referenced by WindowFunc nodes; it must be unique
1646 * among the members of a Query's windowClause list.
1647 * When refname isn't null, the partitionClause is always copied from there;
1648 * the orderClause might or might not be copied (see copiedOrder); the framing
1649 * options are never copied, per spec.
1650 */
1651typedef struct WindowClause
1652{
1654 /* window name (NULL in an OVER clause) */
1656 /* referenced window name, if any */
1658 List *partitionClause; /* PARTITION BY list */
1659 /* ORDER BY list */
1661 int frameOptions; /* frame_clause options, see WindowDef */
1662 Node *startOffset; /* expression for starting bound, if any */
1663 Node *endOffset; /* expression for ending bound, if any */
1664 /* in_range function for startOffset */
1666 /* in_range function for endOffset */
1668 /* collation for in_range tests */
1670 /* use ASC sort order for in_range tests? */
1672 /* nulls sort first for in_range tests? */
1673 bool inRangeNullsFirst pg_node_attr(query_jumble_ignore);
1674 Index winref; /* ID referenced by window functions */
1675 /* did we copy orderClause from refname? */
1678
1679/*
1680 * RowMarkClause -
1681 * parser output representation of FOR [KEY] UPDATE/SHARE clauses
1682 *
1683 * Query.rowMarks contains a separate RowMarkClause node for each relation
1684 * identified as a FOR [KEY] UPDATE/SHARE target. If one of these clauses
1685 * is applied to a subquery, we generate RowMarkClauses for all normal and
1686 * subquery rels in the subquery, but they are marked pushedDown = true to
1687 * distinguish them from clauses that were explicitly written at this query
1688 * level. Also, Query.hasForUpdate tells whether there were explicit FOR
1689 * UPDATE/SHARE/KEY SHARE clauses in the current query level.
1690 */
1691typedef struct RowMarkClause
1692{
1694 Index rti; /* range table index of target relation */
1696 LockWaitPolicy waitPolicy; /* NOWAIT and SKIP LOCKED */
1697 bool pushedDown; /* pushed down from higher query level? */
1699
1700/*
1701 * ForPortionOfClause
1702 * representation of FOR PORTION OF <range-name> FROM <target-start> TO
1703 * <target-end> or FOR PORTION OF <range-name> (<target>)
1704 */
1706{
1708 char *range_name; /* column name of the range/multirange */
1709 ParseLoc location; /* token location, or -1 if unknown */
1710 ParseLoc target_location; /* token location, or -1 if unknown */
1711 Node *target; /* Expr from FOR PORTION OF col (...) syntax */
1712 Node *target_start; /* Expr from FROM ... TO ... syntax */
1713 Node *target_end; /* Expr from FROM ... TO ... syntax */
1715
1716/*
1717 * WithClause -
1718 * representation of WITH clause
1719 *
1720 * Note: WithClause does not propagate into the Query representation;
1721 * but CommonTableExpr does.
1722 */
1723typedef struct WithClause
1724{
1726 List *ctes; /* list of CommonTableExprs */
1727 bool recursive; /* true = WITH RECURSIVE */
1728 ParseLoc location; /* token location, or -1 if unknown */
1730
1731/*
1732 * InferClause -
1733 * ON CONFLICT unique index inference clause
1734 *
1735 * Note: InferClause does not propagate into the Query representation.
1736 */
1737typedef struct InferClause
1738{
1740 List *indexElems; /* IndexElems to infer unique index */
1741 Node *whereClause; /* qualification (partial-index predicate) */
1742 char *conname; /* Constraint name, or NULL if unnamed */
1743 ParseLoc location; /* token location, or -1 if unknown */
1745
1746/*
1747 * OnConflictClause -
1748 * representation of ON CONFLICT clause
1749 *
1750 * Note: OnConflictClause does not propagate into the Query representation.
1751 */
1752typedef struct OnConflictClause
1753{
1755 OnConflictAction action; /* DO NOTHING, SELECT, or UPDATE */
1756 InferClause *infer; /* Optional index inference clause */
1757 LockClauseStrength lockStrength; /* lock strength for DO SELECT */
1758 List *targetList; /* target list (of ResTarget) for DO UPDATE */
1759 Node *whereClause; /* qualifications */
1760 ParseLoc location; /* token location, or -1 if unknown */
1762
1763/*
1764 * CommonTableExpr -
1765 * representation of WITH list element
1766 */
1767
1768typedef enum CTEMaterialize
1769{
1770 CTEMaterializeDefault, /* no option specified */
1771 CTEMaterializeAlways, /* MATERIALIZED */
1772 CTEMaterializeNever, /* NOT MATERIALIZED */
1774
1783
1784typedef struct CTECycleClause
1785{
1793 /* These fields are set during parse analysis: */
1794 Oid cycle_mark_type; /* common type of _value and _default */
1797 Oid cycle_mark_neop; /* <> operator for type */
1799
1800typedef struct CommonTableExpr
1801{
1803
1804 /*
1805 * Query name (never qualified). The string name is included in the query
1806 * jumbling because RTE_CTE RTEs need it.
1807 */
1808 char *ctename;
1809 /* optional list of column names */
1811 CTEMaterialize ctematerialized; /* is this an optimization fence? */
1812 /* SelectStmt/InsertStmt/etc before parse analysis, Query afterwards: */
1813 Node *ctequery; /* the CTE's subquery */
1816 ParseLoc location; /* token location, or -1 if unknown */
1817 /* These fields are set during parse analysis: */
1818 /* is this CTE actually recursive? */
1820
1821 /*
1822 * Number of RTEs referencing this CTE (excluding internal
1823 * self-references).
1824 */
1826 /* list of output column names */
1828 /* OID list of output column type OIDs */
1830 /* integer list of output column typmods */
1832 /* OID list of column collation OIDs */
1835
1836/* Convenience macro to get the output tlist of a CTE's query */
1837#define GetCTETargetList(cte) \
1838 (AssertMacro(IsA((cte)->ctequery, Query)), \
1839 ((Query *) (cte)->ctequery)->commandType == CMD_SELECT ? \
1840 ((Query *) (cte)->ctequery)->targetList : \
1841 ((Query *) (cte)->ctequery)->returningList)
1842
1843/*
1844 * MergeWhenClause -
1845 * raw parser representation of a WHEN clause in a MERGE statement
1846 *
1847 * This is transformed into MergeAction by parse analysis
1848 */
1849typedef struct MergeWhenClause
1850{
1852 MergeMatchKind matchKind; /* MATCHED/NOT MATCHED BY SOURCE/TARGET */
1853 CmdType commandType; /* INSERT/UPDATE/DELETE/DO NOTHING */
1854 OverridingKind override; /* OVERRIDING clause */
1855 Node *condition; /* WHEN conditions (raw parser) */
1856 List *targetList; /* INSERT/UPDATE targetlist */
1857 /* the following members are only used in INSERT actions */
1858 List *values; /* VALUES to INSERT, or NULL */
1860
1861/*
1862 * ReturningOptionKind -
1863 * Possible kinds of option in RETURNING WITH(...) list
1864 *
1865 * Currently, this is used only for specifying OLD/NEW aliases.
1866 */
1868{
1869 RETURNING_OPTION_OLD, /* specify alias for OLD in RETURNING */
1870 RETURNING_OPTION_NEW, /* specify alias for NEW in RETURNING */
1872
1873/*
1874 * ReturningOption -
1875 * An individual option in the RETURNING WITH(...) list
1876 */
1877typedef struct ReturningOption
1878{
1880 ReturningOptionKind option; /* specified option */
1881 char *value; /* option's value */
1882 ParseLoc location; /* token location, or -1 if unknown */
1884
1885/*
1886 * ReturningClause -
1887 * List of RETURNING expressions, together with any WITH(...) options
1888 */
1889typedef struct ReturningClause
1890{
1892 List *options; /* list of ReturningOption elements */
1893 List *exprs; /* list of expressions to return */
1895
1896/*
1897 * TriggerTransition -
1898 * representation of transition row or table naming clause
1899 *
1900 * Only transition tables are initially supported in the syntax, and only for
1901 * AFTER triggers, but other permutations are accepted by the parser so we can
1902 * give a meaningful message from C code.
1903 */
1911
1912/* Nodes for SQL/JSON support */
1913
1914/*
1915 * JsonOutput -
1916 * representation of JSON output clause (RETURNING type [FORMAT format])
1917 */
1918typedef struct JsonOutput
1919{
1921 TypeName *typeName; /* RETURNING type name, if specified */
1922 JsonReturning *returning; /* RETURNING FORMAT clause and type Oids */
1924
1925/*
1926 * JsonArgument -
1927 * representation of argument from JSON PASSING clause
1928 */
1929typedef struct JsonArgument
1930{
1932 JsonValueExpr *val; /* argument value expression */
1933 char *name; /* argument name */
1935
1936/*
1937 * JsonQuotes -
1938 * representation of [KEEP|OMIT] QUOTES clause for JSON_QUERY()
1939 */
1940typedef enum JsonQuotes
1941{
1942 JS_QUOTES_UNSPEC, /* unspecified */
1943 JS_QUOTES_KEEP, /* KEEP QUOTES */
1944 JS_QUOTES_OMIT, /* OMIT QUOTES */
1946
1947/*
1948 * JsonFuncExpr -
1949 * untransformed representation of function expressions for
1950 * SQL/JSON query functions
1951 */
1952typedef struct JsonFuncExpr
1953{
1955 JsonExprOp op; /* expression type */
1956 char *column_name; /* JSON_TABLE() column name or NULL if this is
1957 * not for a JSON_TABLE() */
1958 JsonValueExpr *context_item; /* context item expression */
1959 Node *pathspec; /* JSON path specification expression */
1960 List *passing; /* list of PASSING clause arguments, if any */
1961 JsonOutput *output; /* output clause, if specified */
1962 JsonBehavior *on_empty; /* ON EMPTY behavior */
1963 JsonBehavior *on_error; /* ON ERROR behavior */
1964 JsonWrapper wrapper; /* array wrapper behavior (JSON_QUERY only) */
1965 JsonQuotes quotes; /* omit or keep quotes? (JSON_QUERY only) */
1966 ParseLoc location; /* token location, or -1 if unknown */
1968
1969/*
1970 * JsonTablePathSpec
1971 * untransformed specification of JSON path expression with an optional
1972 * name
1973 */
1983
1984/*
1985 * JsonTable -
1986 * untransformed representation of JSON_TABLE
1987 */
1988typedef struct JsonTable
1989{
1991 JsonValueExpr *context_item; /* context item expression */
1992 JsonTablePathSpec *pathspec; /* JSON path specification */
1993 List *passing; /* list of PASSING clause arguments, if any */
1994 List *columns; /* list of JsonTableColumn */
1995 JsonBehavior *on_error; /* ON ERROR behavior */
1996 Alias *alias; /* table alias in FROM clause */
1997 bool lateral; /* does it have LATERAL prefix? */
1998 ParseLoc location; /* token location, or -1 if unknown */
2000
2001/*
2002 * JsonTableColumnType -
2003 * enumeration of JSON_TABLE column types
2004 */
2013
2014/*
2015 * JsonTableColumn -
2016 * untransformed representation of JSON_TABLE column
2017 */
2018typedef struct JsonTableColumn
2019{
2021 JsonTableColumnType coltype; /* column type */
2022 char *name; /* column name */
2023 TypeName *typeName; /* column type name */
2024 JsonTablePathSpec *pathspec; /* JSON path specification */
2025 JsonFormat *format; /* JSON format clause, if specified */
2026 JsonWrapper wrapper; /* WRAPPER behavior for formatted columns */
2027 JsonQuotes quotes; /* omit or keep quotes on scalar strings? */
2028 List *columns; /* nested columns */
2029 JsonBehavior *on_empty; /* ON EMPTY behavior */
2030 JsonBehavior *on_error; /* ON ERROR behavior */
2031 ParseLoc location; /* token location, or -1 if unknown */
2033
2034/*
2035 * JsonKeyValue -
2036 * untransformed representation of JSON object key-value pair for
2037 * JSON_OBJECT() and JSON_OBJECTAGG()
2038 */
2039typedef struct JsonKeyValue
2040{
2042 Expr *key; /* key expression */
2043 JsonValueExpr *value; /* JSON value expression */
2045
2046/*
2047 * JsonParseExpr -
2048 * untransformed representation of JSON()
2049 */
2050typedef struct JsonParseExpr
2051{
2053 JsonValueExpr *expr; /* string expression */
2054 JsonOutput *output; /* RETURNING clause, if specified */
2055 bool unique_keys; /* WITH UNIQUE KEYS? */
2056 ParseLoc location; /* token location, or -1 if unknown */
2058
2059/*
2060 * JsonScalarExpr -
2061 * untransformed representation of JSON_SCALAR()
2062 */
2063typedef struct JsonScalarExpr
2064{
2066 Expr *expr; /* scalar expression */
2067 JsonOutput *output; /* RETURNING clause, if specified */
2068 ParseLoc location; /* token location, or -1 if unknown */
2070
2071/*
2072 * JsonSerializeExpr -
2073 * untransformed representation of JSON_SERIALIZE() function
2074 */
2075typedef struct JsonSerializeExpr
2076{
2078 JsonValueExpr *expr; /* json value expression */
2079 JsonOutput *output; /* RETURNING clause, if specified */
2080 ParseLoc location; /* token location, or -1 if unknown */
2082
2083/*
2084 * JsonObjectConstructor -
2085 * untransformed representation of JSON_OBJECT() constructor
2086 */
2088{
2090 List *exprs; /* list of JsonKeyValue pairs */
2091 JsonOutput *output; /* RETURNING clause, if specified */
2092 bool absent_on_null; /* skip NULL values? */
2093 bool unique; /* check key uniqueness? */
2094 ParseLoc location; /* token location, or -1 if unknown */
2096
2097/*
2098 * JsonArrayConstructor -
2099 * untransformed representation of JSON_ARRAY(element,...) constructor
2100 */
2102{
2104 List *exprs; /* list of JsonValueExpr elements */
2105 JsonOutput *output; /* RETURNING clause, if specified */
2106 bool absent_on_null; /* skip NULL elements? */
2107 ParseLoc location; /* token location, or -1 if unknown */
2109
2110/*
2111 * JsonArrayQueryConstructor -
2112 * untransformed representation of JSON_ARRAY(subquery) constructor
2113 */
2115{
2117 Node *query; /* subquery */
2118 JsonOutput *output; /* RETURNING clause, if specified */
2119 JsonFormat *format; /* FORMAT clause for subquery, if specified */
2120 bool absent_on_null; /* skip NULL elements? */
2121 ParseLoc location; /* token location, or -1 if unknown */
2123
2124/*
2125 * JsonAggConstructor -
2126 * common fields of untransformed representation of
2127 * JSON_ARRAYAGG() and JSON_OBJECTAGG()
2128 */
2130{
2132 JsonOutput *output; /* RETURNING clause, if any */
2133 Node *agg_filter; /* FILTER clause, if any */
2134 List *agg_order; /* ORDER BY clause, if any */
2135 struct WindowDef *over; /* OVER clause, if any */
2136 ParseLoc location; /* token location, or -1 if unknown */
2138
2139/*
2140 * JsonObjectAgg -
2141 * untransformed representation of JSON_OBJECTAGG()
2142 */
2143typedef struct JsonObjectAgg
2144{
2146 JsonAggConstructor *constructor; /* common fields */
2147 JsonKeyValue *arg; /* object key-value pair */
2148 bool absent_on_null; /* skip NULL values? */
2149 bool unique; /* check key uniqueness? */
2151
2152/*
2153 * JsonArrayAgg -
2154 * untransformed representation of JSON_ARRAYAGG()
2155 */
2156typedef struct JsonArrayAgg
2157{
2159 JsonAggConstructor *constructor; /* common fields */
2160 JsonValueExpr *arg; /* array element expression */
2161 bool absent_on_null; /* skip NULL elements? */
2163
2164
2165/*****************************************************************************
2166 * Raw Grammar Output Statements
2167 *****************************************************************************/
2168
2169/*
2170 * RawStmt --- container for any one statement's raw parse tree
2171 *
2172 * Parse analysis converts a raw parse tree headed by a RawStmt node into
2173 * an analyzed statement headed by a Query node. For optimizable statements,
2174 * the conversion is complex. For utility statements, the parser usually just
2175 * transfers the raw parse tree (sans RawStmt) into the utilityStmt field of
2176 * the Query node, and all the useful work happens at execution time.
2177 *
2178 * stmt_location/stmt_len identify the portion of the source text string
2179 * containing this raw statement (useful for multi-statement strings).
2180 *
2181 * This is irrelevant for query jumbling, as this is not used in parsed
2182 * queries.
2183 */
2184typedef struct RawStmt
2185{
2187
2188 NodeTag type;
2189 Node *stmt; /* raw parse tree */
2190 ParseLoc stmt_location; /* start location, or -1 if unknown */
2191 ParseLoc stmt_len; /* length in bytes; 0 means "rest of string" */
2193
2194/*****************************************************************************
2195 * Optimizable Statements
2196 *****************************************************************************/
2197
2198/* ----------------------
2199 * Insert Statement
2200 *
2201 * The source expression is represented by SelectStmt for both the
2202 * SELECT and VALUES cases. If selectStmt is NULL, then the query
2203 * is INSERT ... DEFAULT VALUES.
2204 * ----------------------
2205 */
2206typedef struct InsertStmt
2207{
2209 RangeVar *relation; /* relation to insert into */
2210 List *cols; /* optional: names of the target columns */
2211 Node *selectStmt; /* the source SELECT/VALUES, or NULL */
2212 OnConflictClause *onConflictClause; /* ON CONFLICT clause */
2213 ReturningClause *returningClause; /* RETURNING clause */
2214 WithClause *withClause; /* WITH clause */
2215 OverridingKind override; /* OVERRIDING clause */
2217
2218/* ----------------------
2219 * Delete Statement
2220 * ----------------------
2221 */
2222typedef struct DeleteStmt
2223{
2225 RangeVar *relation; /* relation to delete from */
2226 List *usingClause; /* optional using clause for more tables */
2227 Node *whereClause; /* qualifications */
2228 ReturningClause *returningClause; /* RETURNING clause */
2229 WithClause *withClause; /* WITH clause */
2230 ForPortionOfClause *forPortionOf; /* FOR PORTION OF clause */
2232
2233/* ----------------------
2234 * Update Statement
2235 * ----------------------
2236 */
2237typedef struct UpdateStmt
2238{
2240 RangeVar *relation; /* relation to update */
2241 List *targetList; /* the target list (of ResTarget) */
2242 Node *whereClause; /* qualifications */
2243 List *fromClause; /* optional from clause for more tables */
2244 ReturningClause *returningClause; /* RETURNING clause */
2245 WithClause *withClause; /* WITH clause */
2246 ForPortionOfClause *forPortionOf; /* FOR PORTION OF clause */
2248
2249/* ----------------------
2250 * Merge Statement
2251 * ----------------------
2252 */
2253typedef struct MergeStmt
2254{
2256 RangeVar *relation; /* target relation to merge into */
2257 Node *sourceRelation; /* source relation */
2258 Node *joinCondition; /* join condition between source and target */
2259 List *mergeWhenClauses; /* list of MergeWhenClause(es) */
2260 ReturningClause *returningClause; /* RETURNING clause */
2261 WithClause *withClause; /* WITH clause */
2263
2264/* ----------------------
2265 * Select Statement
2266 *
2267 * A "simple" SELECT is represented in the output of gram.y by a single
2268 * SelectStmt node; so is a VALUES construct. A query containing set
2269 * operators (UNION, INTERSECT, EXCEPT) is represented by a tree of SelectStmt
2270 * nodes, in which the leaf nodes are component SELECTs and the internal nodes
2271 * represent UNION, INTERSECT, or EXCEPT operators. Using the same node
2272 * type for both leaf and internal nodes allows gram.y to stick ORDER BY,
2273 * LIMIT, etc, clause values into a SELECT statement without worrying
2274 * whether it is a simple or compound SELECT.
2275 * ----------------------
2276 */
2284
2285typedef struct SelectStmt
2286{
2288
2289 /*
2290 * These fields are used only in "leaf" SelectStmts.
2291 */
2292 List *distinctClause; /* NULL, list of DISTINCT ON exprs, or
2293 * lcons(NIL,NIL) for all (SELECT DISTINCT) */
2294 IntoClause *intoClause; /* target for SELECT INTO */
2295 List *targetList; /* the target list (of ResTarget) */
2296 List *fromClause; /* the FROM clause */
2297 Node *whereClause; /* WHERE qualification */
2298 List *groupClause; /* GROUP BY clauses */
2299 bool groupDistinct; /* Is this GROUP BY DISTINCT? */
2300 bool groupByAll; /* Is this GROUP BY ALL? */
2301 Node *havingClause; /* HAVING conditional-expression */
2302 List *windowClause; /* WINDOW window_name AS (...), ... */
2303
2304 /*
2305 * In a "leaf" node representing a VALUES list, the above fields are all
2306 * null, and instead this field is set. Note that the elements of the
2307 * sublists are just expressions, without ResTarget decoration. Also note
2308 * that a list element can be DEFAULT (represented as a SetToDefault
2309 * node), regardless of the context of the VALUES list. It's up to parse
2310 * analysis to reject that where not valid.
2311 */
2312 List *valuesLists; /* untransformed list of expression lists */
2313
2314 /*
2315 * These fields are used in both "leaf" SelectStmts and upper-level
2316 * SelectStmts.
2317 */
2318 List *sortClause; /* sort clause (a list of SortBy's) */
2319 Node *limitOffset; /* # of result tuples to skip */
2320 Node *limitCount; /* # of result tuples to return */
2321 LimitOption limitOption; /* limit type */
2322 List *lockingClause; /* FOR UPDATE (list of LockingClause's) */
2323 WithClause *withClause; /* WITH clause */
2324
2325 /*
2326 * These fields are used only in upper-level SelectStmts.
2327 */
2328 SetOperation op; /* type of set op */
2329 bool all; /* ALL specified? */
2330 struct SelectStmt *larg; /* left child */
2331 struct SelectStmt *rarg; /* right child */
2332 /* Eventually add fields for CORRESPONDING spec here */
2334
2335
2336/* ----------------------
2337 * Set Operation node for post-analysis query trees
2338 *
2339 * After parse analysis, a SELECT with set operations is represented by a
2340 * top-level Query node containing the leaf SELECTs as subqueries in its
2341 * range table. Its setOperations field shows the tree of set operations,
2342 * with leaf SelectStmt nodes replaced by RangeTblRef nodes, and internal
2343 * nodes replaced by SetOperationStmt nodes. Information about the output
2344 * column types is added, too. (Note that the child nodes do not necessarily
2345 * produce these types directly, but we've checked that their output types
2346 * can be coerced to the output column type.) Also, if it's not UNION ALL,
2347 * information about the types' sort/group semantics is provided in the form
2348 * of a SortGroupClause list (same representation as, eg, DISTINCT).
2349 * The resolved common column collations are provided too; but note that if
2350 * it's not UNION ALL, it's okay for a column to not have a common collation,
2351 * so a member of the colCollations list could be InvalidOid even though the
2352 * column has a collatable type.
2353 * ----------------------
2354 */
2355typedef struct SetOperationStmt
2356{
2358 SetOperation op; /* type of set op */
2359 bool all; /* ALL specified? */
2360 Node *larg; /* left child */
2361 Node *rarg; /* right child */
2362 /* Eventually add fields for CORRESPONDING spec here */
2363
2364 /* Fields derived during parse analysis: */
2365 /* OID list of output column type OIDs */
2367 /* integer list of output column typmods */
2369 /* OID list of output column collation OIDs */
2371 /* a list of SortGroupClause's */
2373 /* groupClauses is NIL if UNION ALL, but must be set otherwise */
2375
2376
2377/*
2378 * RETURN statement (inside SQL function body)
2379 */
2385
2386
2387/* ----------------------
2388 * PL/pgSQL Assignment Statement
2389 *
2390 * Like SelectStmt, this is transformed into a SELECT Query.
2391 * However, the targetlist of the result looks more like an UPDATE.
2392 * ----------------------
2393 */
2394typedef struct PLAssignStmt
2395{
2397
2398 char *name; /* initial column name */
2399 List *indirection; /* subscripts and field names, if any */
2400 int nnames; /* number of names to use in ColumnRef */
2401 SelectStmt *val; /* the PL/pgSQL expression to assign */
2402 ParseLoc location; /* name's token location, or -1 if unknown */
2404
2405
2406/*****************************************************************************
2407 * Other Statements (no optimizations required)
2408 *
2409 * These are not touched by parser/analyze.c except to put them into
2410 * the utilityStmt field of a Query. This is eventually passed to
2411 * ProcessUtility (by-passing rewriting and planning). Some of the
2412 * statements do need attention from parse analysis, and this is
2413 * done by routines in parser/parse_utilcmd.c after ProcessUtility
2414 * receives the command for execution.
2415 * DECLARE CURSOR, EXPLAIN, and CREATE TABLE AS are special cases:
2416 * they contain optimizable statements, which get processed normally
2417 * by parser/analyze.c.
2418 *****************************************************************************/
2419
2420/*
2421 * When a command can act on several kinds of objects with only one
2422 * parse structure required, use these constants to designate the
2423 * object type. Note that commands typically don't support all the types.
2424 */
2425
2482
2483/* ----------------------
2484 * Create Schema Statement
2485 *
2486 * NOTE: the schemaElts list contains raw parsetrees for component statements
2487 * of the schema, such as CREATE TABLE, GRANT, etc. These are analyzed and
2488 * executed after the schema itself is created.
2489 * ----------------------
2490 */
2491typedef struct CreateSchemaStmt
2492{
2494 char *schemaname; /* the name of the schema to create */
2495 RoleSpec *authrole; /* the owner of the created schema */
2496 List *schemaElts; /* schema components (list of parsenodes) */
2497 bool if_not_exists; /* just do nothing if schema already exists? */
2499
2500typedef enum DropBehavior
2501{
2502 DROP_RESTRICT, /* drop fails if any dependent objects */
2503 DROP_CASCADE, /* remove dependent objects too */
2505
2506/* ----------------------
2507 * Alter Table
2508 * ----------------------
2509 */
2510typedef struct AlterTableStmt
2511{
2513 RangeVar *relation; /* table to work on */
2514 List *cmds; /* list of subcommands */
2515 ObjectType objtype; /* type of object */
2516 bool missing_ok; /* skip error if table missing */
2518
2519typedef enum AlterTableType
2520{
2521 AT_AddColumn, /* add column */
2522 AT_AddColumnToView, /* implicitly via CREATE OR REPLACE VIEW */
2523 AT_ColumnDefault, /* alter column default */
2524 AT_CookedColumnDefault, /* add a pre-cooked column default */
2525 AT_DropNotNull, /* alter column drop not null */
2526 AT_SetNotNull, /* alter column set not null */
2527 AT_SetExpression, /* alter column set expression */
2528 AT_DropExpression, /* alter column drop expression */
2529 AT_SetStatistics, /* alter column set statistics */
2530 AT_SetOptions, /* alter column set ( options ) */
2531 AT_ResetOptions, /* alter column reset ( options ) */
2532 AT_SetStorage, /* alter column set storage */
2533 AT_SetCompression, /* alter column set compression */
2534 AT_DropColumn, /* drop column */
2535 AT_AddIndex, /* add index */
2536 AT_ReAddIndex, /* internal to commands/tablecmds.c */
2537 AT_AddConstraint, /* add constraint */
2538 AT_ReAddConstraint, /* internal to commands/tablecmds.c */
2539 AT_ReAddDomainConstraint, /* internal to commands/tablecmds.c */
2540 AT_AlterConstraint, /* alter constraint */
2541 AT_ValidateConstraint, /* validate constraint */
2542 AT_AddIndexConstraint, /* add constraint using existing index */
2543 AT_DropConstraint, /* drop constraint */
2544 AT_ReAddComment, /* internal to commands/tablecmds.c */
2545 AT_AlterColumnType, /* alter column type */
2546 AT_AlterColumnGenericOptions, /* alter column OPTIONS (...) */
2547 AT_ChangeOwner, /* change owner */
2548 AT_ClusterOn, /* CLUSTER ON */
2549 AT_DropCluster, /* SET WITHOUT CLUSTER */
2550 AT_SetLogged, /* SET LOGGED */
2551 AT_SetUnLogged, /* SET UNLOGGED */
2552 AT_DropOids, /* SET WITHOUT OIDS */
2553 AT_SetAccessMethod, /* SET ACCESS METHOD */
2554 AT_SetTableSpace, /* SET TABLESPACE */
2555 AT_SetRelOptions, /* SET (...) -- AM specific parameters */
2556 AT_ResetRelOptions, /* RESET (...) -- AM specific parameters */
2557 AT_ReplaceRelOptions, /* replace reloption list in its entirety */
2558 AT_EnableTrig, /* ENABLE TRIGGER name */
2559 AT_EnableAlwaysTrig, /* ENABLE ALWAYS TRIGGER name */
2560 AT_EnableReplicaTrig, /* ENABLE REPLICA TRIGGER name */
2561 AT_DisableTrig, /* DISABLE TRIGGER name */
2562 AT_EnableTrigAll, /* ENABLE TRIGGER ALL */
2563 AT_DisableTrigAll, /* DISABLE TRIGGER ALL */
2564 AT_EnableTrigUser, /* ENABLE TRIGGER USER */
2565 AT_DisableTrigUser, /* DISABLE TRIGGER USER */
2566 AT_EnableRule, /* ENABLE RULE name */
2567 AT_EnableAlwaysRule, /* ENABLE ALWAYS RULE name */
2568 AT_EnableReplicaRule, /* ENABLE REPLICA RULE name */
2569 AT_DisableRule, /* DISABLE RULE name */
2570 AT_AddInherit, /* INHERIT parent */
2571 AT_DropInherit, /* NO INHERIT parent */
2572 AT_AddOf, /* OF <type_name> */
2573 AT_DropOf, /* NOT OF */
2574 AT_ReplicaIdentity, /* REPLICA IDENTITY */
2575 AT_EnableRowSecurity, /* ENABLE ROW SECURITY */
2576 AT_DisableRowSecurity, /* DISABLE ROW SECURITY */
2577 AT_ForceRowSecurity, /* FORCE ROW SECURITY */
2578 AT_NoForceRowSecurity, /* NO FORCE ROW SECURITY */
2579 AT_GenericOptions, /* OPTIONS (...) */
2580 AT_AttachPartition, /* ATTACH PARTITION */
2581 AT_DetachPartition, /* DETACH PARTITION */
2582 AT_DetachPartitionFinalize, /* DETACH PARTITION FINALIZE */
2583 AT_SplitPartition, /* SPLIT PARTITION */
2584 AT_MergePartitions, /* MERGE PARTITIONS */
2585 AT_AddIdentity, /* ADD IDENTITY */
2586 AT_SetIdentity, /* SET identity column options */
2587 AT_DropIdentity, /* DROP IDENTITY */
2588 AT_ReAddStatistics, /* internal to commands/tablecmds.c */
2590
2591typedef struct AlterTableCmd /* one subcommand of an ALTER TABLE */
2592{
2594 AlterTableType subtype; /* Type of table alteration to apply */
2595 char *name; /* column, constraint, or trigger to act on,
2596 * or tablespace, access method */
2597 int16 num; /* attribute number for columns referenced by
2598 * number */
2600 Node *def; /* definition of new column, index,
2601 * constraint, or parent table */
2602 DropBehavior behavior; /* RESTRICT or CASCADE for DROP cases */
2603 bool missing_ok; /* skip error if missing? */
2604 bool recurse; /* exec-time recursion */
2606
2607/* Ad-hoc node for AT_AlterConstraint */
2608typedef struct ATAlterConstraint
2609{
2611 char *conname; /* Constraint name */
2612 bool alterEnforceability; /* changing enforceability properties? */
2613 bool is_enforced; /* ENFORCED? */
2614 bool alterDeferrability; /* changing deferrability properties? */
2615 bool deferrable; /* DEFERRABLE? */
2616 bool initdeferred; /* INITIALLY DEFERRED? */
2617 bool alterInheritability; /* changing inheritability properties */
2620
2621/* Ad-hoc node for AT_ReplicaIdentity */
2628
2629
2630/* ----------------------
2631 * Alter Collation
2632 * ----------------------
2633 */
2639
2640
2641/* ----------------------
2642 * Alter Domain
2643 *
2644 * The fields are used in different ways by the different variants of
2645 * this command.
2646 * ----------------------
2647 */
2649{
2650 AD_AlterDefault = 'T', /* SET|DROP DEFAULT */
2651 AD_DropNotNull = 'N', /* DROP NOT NULL */
2652 AD_SetNotNull = 'O', /* SET NOT NULL */
2653 AD_AddConstraint = 'C', /* ADD CONSTRAINT */
2654 AD_DropConstraint = 'X', /* DROP CONSTRAINT */
2655 AD_ValidateConstraint = 'V', /* VALIDATE CONSTRAINT */
2657
2658typedef struct AlterDomainStmt
2659{
2661 AlterDomainType subtype; /* subtype of command */
2662 List *typeName; /* domain to work on */
2663 char *name; /* column or constraint name to act on */
2664 Node *def; /* definition of default or constraint */
2665 DropBehavior behavior; /* RESTRICT or CASCADE for DROP cases */
2666 bool missing_ok; /* skip error if missing? */
2668
2669
2670/* ----------------------
2671 * Grant|Revoke Statement
2672 * ----------------------
2673 */
2675{
2676 ACL_TARGET_OBJECT, /* grant on specific named object(s) */
2677 ACL_TARGET_ALL_IN_SCHEMA, /* grant on all objects in given schema(s) */
2678 ACL_TARGET_DEFAULTS, /* ALTER DEFAULT PRIVILEGES */
2680
2681typedef struct GrantStmt
2682{
2684 bool is_grant; /* true = GRANT, false = REVOKE */
2685 GrantTargetType targtype; /* type of the grant target */
2686 ObjectType objtype; /* kind of object being operated on */
2687 List *objects; /* list of RangeVar nodes, ObjectWithArgs
2688 * nodes, or plain names (as String values) */
2689 List *privileges; /* list of AccessPriv nodes */
2690 /* privileges == NIL denotes ALL PRIVILEGES */
2691 List *grantees; /* list of RoleSpec nodes */
2692 bool grant_option; /* grant or revoke grant option */
2693 RoleSpec *grantor; /* GRANTED BY clause, or NULL if none */
2694 DropBehavior behavior; /* drop behavior (for REVOKE) */
2696
2697/*
2698 * ObjectWithArgs represents a function/procedure/operator name plus parameter
2699 * identification.
2700 *
2701 * objargs includes only the types of the input parameters of the object.
2702 * In some contexts, that will be all we have, and it's enough to look up
2703 * objects according to the traditional Postgres rules (i.e., when only input
2704 * arguments matter).
2705 *
2706 * objfuncargs, if not NIL, carries the full specification of the parameter
2707 * list, including parameter mode annotations.
2708 *
2709 * Some grammar productions can set args_unspecified = true instead of
2710 * providing parameter info. In this case, lookup will succeed only if
2711 * the object name is unique. Note that otherwise, NIL parameter lists
2712 * mean zero arguments.
2713 */
2714typedef struct ObjectWithArgs
2715{
2717 List *objname; /* qualified name of function/operator */
2718 List *objargs; /* list of Typename nodes (input args only) */
2719 List *objfuncargs; /* list of FunctionParameter nodes */
2720 bool args_unspecified; /* argument list was omitted? */
2722
2723/*
2724 * An access privilege, with optional list of column names
2725 * priv_name == NULL denotes ALL PRIVILEGES (only used with a column list)
2726 * cols == NIL denotes "all columns"
2727 * Note that simple "ALL PRIVILEGES" is represented as a NIL list, not
2728 * an AccessPriv with both fields null.
2729 */
2730typedef struct AccessPriv
2731{
2733 char *priv_name; /* string name of privilege */
2734 List *cols; /* list of String */
2736
2737/* ----------------------
2738 * Grant/Revoke Role Statement
2739 *
2740 * Note: because of the parsing ambiguity with the GRANT <privileges>
2741 * statement, granted_roles is a list of AccessPriv; the execution code
2742 * should complain if any column lists appear. grantee_roles is a list
2743 * of role names, as RoleSpec values.
2744 * ----------------------
2745 */
2746typedef struct GrantRoleStmt
2747{
2749 List *granted_roles; /* list of roles to be granted/revoked */
2750 List *grantee_roles; /* list of member roles to add/delete */
2751 bool is_grant; /* true = GRANT, false = REVOKE */
2752 List *opt; /* options e.g. WITH GRANT OPTION */
2753 RoleSpec *grantor; /* set grantor to other than current role */
2754 DropBehavior behavior; /* drop behavior (for REVOKE) */
2756
2757/* ----------------------
2758 * Alter Default Privileges Statement
2759 * ----------------------
2760 */
2762{
2764 List *options; /* list of DefElem */
2765 GrantStmt *action; /* GRANT/REVOKE action (with objects=NIL) */
2767
2768/* ----------------------
2769 * Copy Statement
2770 *
2771 * We support "COPY relation FROM file", "COPY relation TO file", and
2772 * "COPY (query) TO file". In any given CopyStmt, exactly one of "relation"
2773 * and "query" must be non-NULL.
2774 * ----------------------
2775 */
2776typedef struct CopyStmt
2777{
2779 RangeVar *relation; /* the relation to copy */
2780 Node *query; /* the query (SELECT or DML statement with
2781 * RETURNING) to copy, as a raw parse tree */
2782 List *attlist; /* List of column names (as Strings), or NIL
2783 * for all columns */
2784 bool is_from; /* TO or FROM */
2785 bool is_program; /* is 'filename' a program to popen? */
2786 char *filename; /* filename, or NULL for STDIN/STDOUT */
2787 List *options; /* List of DefElem nodes */
2788 Node *whereClause; /* WHERE condition (or NULL) */
2790
2791/* ----------------------
2792 * SET Statement (includes RESET)
2793 *
2794 * "SET var TO DEFAULT" and "RESET var" are semantically equivalent, but we
2795 * preserve the distinction in VariableSetKind for CreateCommandTag().
2796 * ----------------------
2797 */
2799{
2800 VAR_SET_VALUE, /* SET var = value */
2801 VAR_SET_DEFAULT, /* SET var TO DEFAULT */
2802 VAR_SET_CURRENT, /* SET var FROM CURRENT */
2803 VAR_SET_MULTI, /* special case for SET TRANSACTION ... */
2804 VAR_RESET, /* RESET var */
2805 VAR_RESET_ALL, /* RESET ALL */
2807
2808typedef struct VariableSetStmt
2809{
2811
2812 NodeTag type;
2814 /* variable to be set */
2815 char *name;
2816 /* List of A_Const nodes */
2818
2819 /*
2820 * True if arguments should be accounted for in query jumbling. We use a
2821 * separate flag rather than query_jumble_ignore on "args" as several
2822 * grammar flavors of SET rely on a list of values that are parsed
2823 * directly from the grammar's keywords.
2824 */
2826 /* SET LOCAL? */
2828 /* token location, or -1 if unknown */
2831
2832/* ----------------------
2833 * Show Statement
2834 * ----------------------
2835 */
2841
2842/* ----------------------
2843 * Create Table Statement
2844 *
2845 * NOTE: in the raw gram.y output, ColumnDef and Constraint nodes are
2846 * intermixed in tableElts, and constraints and nnconstraints are NIL. After
2847 * parse analysis, tableElts contains just ColumnDefs, nnconstraints contains
2848 * Constraint nodes of CONSTR_NOTNULL type from various sources, and
2849 * constraints contains just CONSTR_CHECK Constraint nodes.
2850 * ----------------------
2851 */
2852
2853typedef struct CreateStmt
2854{
2856 RangeVar *relation; /* relation to create */
2857 List *tableElts; /* column definitions (list of ColumnDef) */
2858 List *inhRelations; /* relations to inherit from (list of
2859 * RangeVar) */
2860 PartitionBoundSpec *partbound; /* FOR VALUES clause */
2861 PartitionSpec *partspec; /* PARTITION BY clause */
2862 TypeName *ofTypename; /* OF typename */
2863 List *constraints; /* constraints (list of Constraint nodes) */
2864 List *nnconstraints; /* NOT NULL constraints (ditto) */
2865 List *options; /* options from WITH clause */
2866 OnCommitAction oncommit; /* what do we do at COMMIT? */
2867 char *tablespacename; /* table space to use, or NULL */
2868 char *accessMethod; /* table access method */
2869 bool if_not_exists; /* just do nothing if it already exists? */
2871
2872/* ----------
2873 * Definitions for constraints in CreateStmt
2874 *
2875 * Note that column defaults are treated as a type of constraint,
2876 * even though that's a bit odd semantically.
2877 *
2878 * For constraints that use expressions (CONSTR_CHECK, CONSTR_DEFAULT)
2879 * we may have the expression in either "raw" form (an untransformed
2880 * parse tree) or "cooked" form (the nodeToString representation of
2881 * an executable expression tree), depending on how this Constraint
2882 * node was created (by parsing, or by inheritance from an existing
2883 * relation). We should never have both in the same node!
2884 *
2885 * FKCONSTR_ACTION_xxx values are stored into pg_constraint.confupdtype
2886 * and pg_constraint.confdeltype columns; FKCONSTR_MATCH_xxx values are
2887 * stored into pg_constraint.confmatchtype. Changing the code values may
2888 * require an initdb!
2889 *
2890 * If skip_validation is true then we skip checking that the existing rows
2891 * in the table satisfy the constraint, and just install the catalog entries
2892 * for the constraint. A new FK constraint is marked as valid iff
2893 * initially_valid is true. (Usually skip_validation and initially_valid
2894 * are inverses, but we can set both true if the table is known empty.)
2895 *
2896 * Constraint attributes (DEFERRABLE etc) are initially represented as
2897 * separate Constraint nodes for simplicity of parsing. parse_utilcmd.c makes
2898 * a pass through the constraints list to insert the info into the appropriate
2899 * Constraint node.
2900 * ----------
2901 */
2902
2923
2924/* Foreign key action codes */
2925#define FKCONSTR_ACTION_NOACTION 'a'
2926#define FKCONSTR_ACTION_RESTRICT 'r'
2927#define FKCONSTR_ACTION_CASCADE 'c'
2928#define FKCONSTR_ACTION_SETNULL 'n'
2929#define FKCONSTR_ACTION_SETDEFAULT 'd'
2930
2931/* Foreign key matchtype codes */
2932#define FKCONSTR_MATCH_FULL 'f'
2933#define FKCONSTR_MATCH_PARTIAL 'p'
2934#define FKCONSTR_MATCH_SIMPLE 's'
2935
2936typedef struct Constraint
2937{
2939 ConstrType contype; /* see above */
2940 char *conname; /* Constraint name, or NULL if unnamed */
2941 bool deferrable; /* DEFERRABLE? */
2942 bool initdeferred; /* INITIALLY DEFERRED? */
2943 bool is_enforced; /* enforced constraint? */
2944 bool skip_validation; /* skip validation of existing rows? */
2945 bool initially_valid; /* mark the new constraint as valid? */
2946 bool is_no_inherit; /* is constraint non-inheritable? */
2947 Node *raw_expr; /* CHECK or DEFAULT expression, as
2948 * untransformed parse tree */
2949 char *cooked_expr; /* CHECK or DEFAULT expression, as
2950 * nodeToString representation */
2951 char generated_when; /* ALWAYS or BY DEFAULT */
2952 char generated_kind; /* STORED or VIRTUAL */
2953 bool nulls_not_distinct; /* null treatment for UNIQUE constraints */
2954 List *keys; /* String nodes naming referenced key
2955 * column(s); for UNIQUE/PK/NOT NULL */
2956 bool without_overlaps; /* WITHOUT OVERLAPS specified */
2957 List *including; /* String nodes naming referenced nonkey
2958 * column(s); for UNIQUE/PK */
2959 List *exclusions; /* list of (IndexElem, operator name) pairs;
2960 * for exclusion constraints */
2961 List *options; /* options from WITH clause */
2962 char *indexname; /* existing index to use; otherwise NULL */
2963 char *indexspace; /* index tablespace; NULL for default */
2964 bool reset_default_tblspc; /* reset default_tablespace prior to
2965 * creating the index */
2966 char *access_method; /* index access method; NULL for default */
2967 Node *where_clause; /* partial index predicate */
2968
2969 /* Fields used for FOREIGN KEY constraints: */
2970 RangeVar *pktable; /* Primary key table */
2971 List *fk_attrs; /* Attributes of foreign key */
2972 List *pk_attrs; /* Corresponding attrs in PK table */
2973 bool fk_with_period; /* Last attribute of FK uses PERIOD */
2974 bool pk_with_period; /* Last attribute of PK uses PERIOD */
2975 char fk_matchtype; /* FULL, PARTIAL, SIMPLE */
2976 char fk_upd_action; /* ON UPDATE action */
2977 char fk_del_action; /* ON DELETE action */
2978 List *fk_del_set_cols; /* ON DELETE SET NULL/DEFAULT (col1, col2) */
2979 List *old_conpfeqop; /* pg_constraint.conpfeqop of my former self */
2980 Oid old_pktable_oid; /* pg_constraint.confrelid of my former
2981 * self */
2982
2983 ParseLoc location; /* token location, or -1 if unknown */
2985
2986/* ----------------------
2987 * Create/Drop Table Space Statements
2988 * ----------------------
2989 */
2990
2999
3001{
3004 bool missing_ok; /* skip error if missing? */
3006
3014
3016{
3019 ObjectType objtype; /* Object type to move */
3020 List *roles; /* List of roles to move objects of */
3024
3025/* ----------------------
3026 * Create/Alter Extension Statements
3027 * ----------------------
3028 */
3029
3031{
3033 char *extname;
3034 bool if_not_exists; /* just do nothing if it already exists? */
3035 List *options; /* List of DefElem nodes */
3037
3038/* Only used for ALTER EXTENSION UPDATE; later might need an action field */
3040{
3042 char *extname;
3043 List *options; /* List of DefElem nodes */
3045
3047{
3049 char *extname; /* Extension's name */
3050 int action; /* +1 = add object, -1 = drop object */
3051 ObjectType objtype; /* Object's type */
3052 Node *object; /* Qualified name of the object */
3054
3055/* ----------------------
3056 * Create/Alter FOREIGN DATA WRAPPER Statements
3057 * ----------------------
3058 */
3059
3060typedef struct CreateFdwStmt
3061{
3063 char *fdwname; /* foreign-data wrapper name */
3064 List *func_options; /* HANDLER/VALIDATOR options */
3065 List *options; /* generic options to FDW */
3067
3068typedef struct AlterFdwStmt
3069{
3071 char *fdwname; /* foreign-data wrapper name */
3072 List *func_options; /* HANDLER/VALIDATOR options */
3073 List *options; /* generic options to FDW */
3075
3076/* ----------------------
3077 * Create/Alter FOREIGN SERVER Statements
3078 * ----------------------
3079 */
3080
3082{
3084 char *servername; /* server name */
3085 char *servertype; /* optional server type */
3086 char *version; /* optional server version */
3087 char *fdwname; /* FDW name */
3088 bool if_not_exists; /* just do nothing if it already exists? */
3089 List *options; /* generic options to server */
3091
3093{
3095 char *servername; /* server name */
3096 char *version; /* optional server version */
3097 List *options; /* generic options to server */
3098 bool has_version; /* version specified */
3100
3101/* ----------------------
3102 * Create FOREIGN TABLE Statement
3103 * ----------------------
3104 */
3105
3112
3113/* ----------------------
3114 * Create/Drop USER MAPPING Statements
3115 * ----------------------
3116 */
3117
3119{
3121 RoleSpec *user; /* user role */
3122 char *servername; /* server name */
3123 bool if_not_exists; /* just do nothing if it already exists? */
3124 List *options; /* generic options to server */
3126
3128{
3130 RoleSpec *user; /* user role */
3131 char *servername; /* server name */
3132 List *options; /* generic options to server */
3134
3136{
3138 RoleSpec *user; /* user role */
3139 char *servername; /* server name */
3140 bool missing_ok; /* ignore missing mappings */
3142
3143/* ----------------------
3144 * Import Foreign Schema Statement
3145 * ----------------------
3146 */
3147
3149{
3150 FDW_IMPORT_SCHEMA_ALL, /* all relations wanted */
3151 FDW_IMPORT_SCHEMA_LIMIT_TO, /* include only listed tables in import */
3152 FDW_IMPORT_SCHEMA_EXCEPT, /* exclude listed tables from import */
3154
3156{
3158 char *server_name; /* FDW server name */
3159 char *remote_schema; /* remote schema name to query */
3160 char *local_schema; /* local schema to create objects in */
3161 ImportForeignSchemaType list_type; /* type of table list */
3162 List *table_list; /* List of RangeVar */
3163 List *options; /* list of options to pass to FDW */
3165
3166/*----------------------
3167 * Create POLICY Statement
3168 *----------------------
3169 */
3170typedef struct CreatePolicyStmt
3171{
3173 char *policy_name; /* Policy's name */
3174 RangeVar *table; /* the table name the policy applies to */
3175 char *cmd_name; /* the command name the policy applies to */
3176 bool permissive; /* restrictive or permissive policy */
3177 List *roles; /* the roles associated with the policy */
3178 Node *qual; /* the policy's condition */
3179 Node *with_check; /* the policy's WITH CHECK condition. */
3181
3182/*----------------------
3183 * Alter POLICY Statement
3184 *----------------------
3185 */
3186typedef struct AlterPolicyStmt
3187{
3189 char *policy_name; /* Policy's name */
3190 RangeVar *table; /* the table name the policy applies to */
3191 List *roles; /* the roles associated with the policy */
3192 Node *qual; /* the policy's condition */
3193 Node *with_check; /* the policy's WITH CHECK condition. */
3195
3196/*----------------------
3197 * Create ACCESS METHOD Statement
3198 *----------------------
3199 */
3200typedef struct CreateAmStmt
3201{
3203 char *amname; /* access method name */
3204 List *handler_name; /* handler function name */
3205 char amtype; /* type of access method */
3207
3208/* ----------------------
3209 * Create TRIGGER Statement
3210 * ----------------------
3211 */
3212typedef struct CreateTrigStmt
3213{
3215 bool replace; /* replace trigger if already exists */
3216 bool isconstraint; /* This is a constraint trigger */
3217 char *trigname; /* TRIGGER's name */
3218 RangeVar *relation; /* relation trigger is on */
3219 List *funcname; /* qual. name of function to call */
3220 List *args; /* list of String or NIL */
3221 bool row; /* ROW/STATEMENT */
3222 /* timing uses the TRIGGER_TYPE bits defined in catalog/pg_trigger.h */
3223 int16 timing; /* BEFORE, AFTER, or INSTEAD */
3224 /* events uses the TRIGGER_TYPE bits defined in catalog/pg_trigger.h */
3225 int16 events; /* "OR" of INSERT/UPDATE/DELETE/TRUNCATE */
3226 List *columns; /* column names, or NIL for all columns */
3227 Node *whenClause; /* qual expression, or NULL if none */
3228 /* explicitly named transition data */
3229 List *transitionRels; /* TriggerTransition nodes, or NIL if none */
3230 /* The remaining fields are only used for constraint triggers */
3231 bool deferrable; /* [NOT] DEFERRABLE */
3232 bool initdeferred; /* INITIALLY {DEFERRED|IMMEDIATE} */
3233 RangeVar *constrrel; /* opposite relation, if RI trigger */
3235
3236/* ----------------------
3237 * Create EVENT TRIGGER Statement
3238 * ----------------------
3239 */
3241{
3243 char *trigname; /* TRIGGER's name */
3244 char *eventname; /* event's identifier */
3245 List *whenclause; /* list of DefElems indicating filtering */
3246 List *funcname; /* qual. name of function to call */
3248
3249/* ----------------------
3250 * Alter EVENT TRIGGER Statement
3251 * ----------------------
3252 */
3254{
3256 char *trigname; /* TRIGGER's name */
3257 char tgenabled; /* trigger's firing configuration WRT
3258 * session_replication_role */
3260
3261/* ----------------------
3262 * Create LANGUAGE Statements
3263 * ----------------------
3264 */
3265typedef struct CreatePLangStmt
3266{
3268 bool replace; /* T => replace if already exists */
3269 char *plname; /* PL name */
3270 List *plhandler; /* PL call handler function (qual. name) */
3271 List *plinline; /* optional inline function (qual. name) */
3272 List *plvalidator; /* optional validator function (qual. name) */
3273 bool pltrusted; /* PL is trusted */
3275
3276/* ----------------------
3277 * Create/Alter/Drop Role Statements
3278 *
3279 * Note: these node types are also used for the backwards-compatible
3280 * Create/Alter/Drop User/Group statements. In the ALTER and DROP cases
3281 * there's really no need to distinguish what the original spelling was,
3282 * but for CREATE we mark the type because the defaults vary.
3283 * ----------------------
3284 */
3291
3292typedef struct CreateRoleStmt
3293{
3295 RoleStmtType stmt_type; /* ROLE/USER/GROUP */
3296 char *role; /* role name */
3297 List *options; /* List of DefElem nodes */
3299
3300typedef struct AlterRoleStmt
3301{
3303 RoleSpec *role; /* role */
3304 List *options; /* List of DefElem nodes */
3305 int action; /* +1 = add members, -1 = drop members */
3307
3308typedef struct AlterRoleSetStmt
3309{
3311 RoleSpec *role; /* role */
3312 char *database; /* database name, or NULL */
3313 VariableSetStmt *setstmt; /* SET or RESET subcommand */
3315
3316typedef struct DropRoleStmt
3317{
3319 List *roles; /* List of roles to remove */
3320 bool missing_ok; /* skip error if a role is missing? */
3322
3323/* ----------------------
3324 * {Create|Alter} SEQUENCE Statement
3325 * ----------------------
3326 */
3327
3328typedef struct CreateSeqStmt
3329{
3331 RangeVar *sequence; /* the sequence to create */
3333 Oid ownerId; /* ID of owner, or InvalidOid for default */
3335 bool if_not_exists; /* just do nothing if it already exists? */
3337
3338typedef struct AlterSeqStmt
3339{
3341 RangeVar *sequence; /* the sequence to alter */
3344 bool missing_ok; /* skip error if a role is missing? */
3346
3347/* ----------------------
3348 * Create {Aggregate|Operator|Type} Statement
3349 * ----------------------
3350 */
3351typedef struct DefineStmt
3352{
3354 ObjectType kind; /* aggregate, operator, type */
3355 bool oldstyle; /* hack to signal old CREATE AGG syntax */
3356 List *defnames; /* qualified name (list of String) */
3357 List *args; /* a list of TypeName (if needed) */
3358 List *definition; /* a list of DefElem */
3359 bool if_not_exists; /* just do nothing if it already exists? */
3360 bool replace; /* replace if already exists? */
3362
3363/* ----------------------
3364 * Create Domain Statement
3365 * ----------------------
3366 */
3367typedef struct CreateDomainStmt
3368{
3370 List *domainname; /* qualified name (list of String) */
3371 TypeName *typeName; /* the base type */
3372 CollateClause *collClause; /* untransformed COLLATE spec, if any */
3373 List *constraints; /* constraints (list of Constraint nodes) */
3375
3376/* ----------------------
3377 * Create Operator Class Statement
3378 * ----------------------
3379 */
3380typedef struct CreateOpClassStmt
3381{
3383 List *opclassname; /* qualified name (list of String) */
3384 List *opfamilyname; /* qualified name (ditto); NIL if omitted */
3385 char *amname; /* name of index AM opclass is for */
3386 TypeName *datatype; /* datatype of indexed column */
3387 List *items; /* List of CreateOpClassItem nodes */
3388 bool isDefault; /* Should be marked as default for type? */
3390
3391#define OPCLASS_ITEM_OPERATOR 1
3392#define OPCLASS_ITEM_FUNCTION 2
3393#define OPCLASS_ITEM_STORAGETYPE 3
3394
3395typedef struct CreateOpClassItem
3396{
3398 int itemtype; /* see codes above */
3399 ObjectWithArgs *name; /* operator or function name and args */
3400 int number; /* strategy num or support proc num */
3401 List *order_family; /* only used for ordering operators */
3402 List *class_args; /* amproclefttype/amprocrighttype or
3403 * amoplefttype/amoprighttype */
3404 /* fields used for a storagetype item: */
3405 TypeName *storedtype; /* datatype stored in index */
3407
3408/* ----------------------
3409 * Create Operator Family Statement
3410 * ----------------------
3411 */
3413{
3415 List *opfamilyname; /* qualified name (list of String) */
3416 char *amname; /* name of index AM opfamily is for */
3418
3419/* ----------------------
3420 * Alter Operator Family Statement
3421 * ----------------------
3422 */
3423typedef struct AlterOpFamilyStmt
3424{
3426 List *opfamilyname; /* qualified name (list of String) */
3427 char *amname; /* name of index AM opfamily is for */
3428 bool isDrop; /* ADD or DROP the items? */
3429 List *items; /* List of CreateOpClassItem nodes */
3431
3432/* ----------------------
3433 * Drop Table|Sequence|View|Index|Type|Domain|Conversion|Schema Statement
3434 * ----------------------
3435 */
3436
3437typedef struct DropStmt
3438{
3440 List *objects; /* list of names */
3441 ObjectType removeType; /* object type */
3442 DropBehavior behavior; /* RESTRICT or CASCADE behavior */
3443 bool missing_ok; /* skip error if object is missing? */
3444 bool concurrent; /* drop index concurrently? */
3446
3447/* ----------------------
3448 * Truncate Table Statement
3449 * ----------------------
3450 */
3451typedef struct TruncateStmt
3452{
3454 List *relations; /* relations (RangeVars) to be truncated */
3455 bool restart_seqs; /* restart owned sequences? */
3456 DropBehavior behavior; /* RESTRICT or CASCADE behavior */
3458
3459/* ----------------------
3460 * Comment On Statement
3461 * ----------------------
3462 */
3463typedef struct CommentStmt
3464{
3466 ObjectType objtype; /* Object's type */
3467 Node *object; /* Qualified name of the object */
3468 char *comment; /* Comment to insert, or NULL to remove */
3470
3471/* ----------------------
3472 * SECURITY LABEL Statement
3473 * ----------------------
3474 */
3475typedef struct SecLabelStmt
3476{
3478 ObjectType objtype; /* Object's type */
3479 Node *object; /* Qualified name of the object */
3480 char *provider; /* Label provider (or NULL) */
3481 char *label; /* New security label to be assigned */
3483
3484/* ----------------------
3485 * Declare Cursor Statement
3486 *
3487 * The "query" field is initially a raw parse tree, and is converted to a
3488 * Query node during parse analysis. Note that rewriting and planning
3489 * of the query are always postponed until execution.
3490 * ----------------------
3491 */
3492#define CURSOR_OPT_BINARY 0x0001 /* BINARY */
3493#define CURSOR_OPT_SCROLL 0x0002 /* SCROLL explicitly given */
3494#define CURSOR_OPT_NO_SCROLL 0x0004 /* NO SCROLL explicitly given */
3495#define CURSOR_OPT_INSENSITIVE 0x0008 /* INSENSITIVE */
3496#define CURSOR_OPT_ASENSITIVE 0x0010 /* ASENSITIVE */
3497#define CURSOR_OPT_HOLD 0x0020 /* WITH HOLD */
3498/* these planner-control flags do not correspond to any SQL grammar: */
3499#define CURSOR_OPT_FAST_PLAN 0x0100 /* prefer fast-start plan */
3500#define CURSOR_OPT_GENERIC_PLAN 0x0200 /* force use of generic plan */
3501#define CURSOR_OPT_CUSTOM_PLAN 0x0400 /* force use of custom plan */
3502#define CURSOR_OPT_PARALLEL_OK 0x0800 /* parallel mode OK */
3503
3504typedef struct DeclareCursorStmt
3505{
3507 char *portalname; /* name of the portal (cursor) */
3508 int options; /* bitmask of options (see above) */
3509 Node *query; /* the query (see comments above) */
3511
3512/* ----------------------
3513 * Close Portal Statement
3514 * ----------------------
3515 */
3516typedef struct ClosePortalStmt
3517{
3519 char *portalname; /* name of the portal (cursor) */
3520 /* NULL means CLOSE ALL */
3522
3523/* ----------------------
3524 * Fetch Statement (also Move)
3525 * ----------------------
3526 */
3527typedef enum FetchDirection
3528{
3529 /* for these, howMany is how many rows to fetch; FETCH_ALL means ALL */
3532 /* for these, howMany indicates a position; only one row is fetched */
3536
3552
3553#define FETCH_ALL LONG_MAX
3554
3555typedef struct FetchStmt
3556{
3558 FetchDirection direction; /* see above */
3559 /* number of rows, or position argument */
3561 /* name of portal (cursor) */
3563 /* true if MOVE */
3565
3566 /*
3567 * Set when a direction_keyword (e.g., FETCH FORWARD) is used, to
3568 * distinguish it from a numeric variant (e.g., FETCH 1) for the purpose
3569 * of query jumbling.
3570 */
3572
3573 /* token location, or -1 if unknown */
3576
3577/* ----------------------
3578 * Create Index Statement
3579 *
3580 * This represents creation of an index and/or an associated constraint.
3581 * If isconstraint is true, we should create a pg_constraint entry along
3582 * with the index. But if indexOid isn't InvalidOid, we are not creating an
3583 * index, just a UNIQUE/PKEY constraint using an existing index. isconstraint
3584 * must always be true in this case, and the fields describing the index
3585 * properties are empty.
3586 * ----------------------
3587 */
3588typedef struct IndexStmt
3589{
3591 char *idxname; /* name of new index, or NULL for default */
3592 RangeVar *relation; /* relation to build index on */
3593 char *accessMethod; /* name of access method (eg. btree) */
3594 char *tableSpace; /* tablespace, or NULL for default */
3595 List *indexParams; /* columns to index: a list of IndexElem */
3596 List *indexIncludingParams; /* additional columns to index: a list
3597 * of IndexElem */
3598 List *options; /* WITH clause options: a list of DefElem */
3599 Node *whereClause; /* qualification (partial-index predicate) */
3600 List *excludeOpNames; /* exclusion operator names, or NIL if none */
3601 char *idxcomment; /* comment to apply to index, or NULL */
3602 Oid indexOid; /* OID of an existing index, if any */
3603 RelFileNumber oldNumber; /* relfilenumber of existing storage, if any */
3604 SubTransactionId oldCreateSubid; /* rd_createSubid of oldNumber */
3605 SubTransactionId oldFirstRelfilelocatorSubid; /* rd_firstRelfilelocatorSubid
3606 * of oldNumber */
3607 bool unique; /* is index unique? */
3608 bool nulls_not_distinct; /* null treatment for UNIQUE constraints */
3609 bool primary; /* is index a primary key? */
3610 bool isconstraint; /* is it for a pkey/unique constraint? */
3611 bool iswithoutoverlaps; /* is the constraint WITHOUT OVERLAPS? */
3612 bool deferrable; /* is the constraint DEFERRABLE? */
3613 bool initdeferred; /* is the constraint INITIALLY DEFERRED? */
3614 bool transformed; /* true when transformIndexStmt is finished */
3615 bool concurrent; /* should this be a concurrent index build? */
3616 bool if_not_exists; /* just do nothing if index already exists? */
3617 bool reset_default_tblspc; /* reset default_tablespace prior to
3618 * executing */
3620
3621/* ----------------------
3622 * Create Statistics Statement
3623 * ----------------------
3624 */
3625typedef struct CreateStatsStmt
3626{
3628 List *defnames; /* qualified name (list of String) */
3629 List *stat_types; /* stat types (list of String) */
3630 List *exprs; /* expressions to build statistics on */
3631 List *relations; /* rels to build stats on (list of RangeVar) */
3632 char *stxcomment; /* comment to apply to stats, or NULL */
3633 bool transformed; /* true when transformStatsStmt is finished */
3634 bool if_not_exists; /* do nothing if stats name already exists */
3636
3637/*
3638 * StatsElem - statistics parameters (used in CREATE STATISTICS)
3639 *
3640 * For a plain attribute, 'name' is the name of the referenced table column
3641 * and 'expr' is NULL. For an expression, 'name' is NULL and 'expr' is the
3642 * expression tree.
3643 */
3644typedef struct StatsElem
3645{
3647 char *name; /* name of attribute to index, or NULL */
3648 Node *expr; /* expression to index, or NULL */
3650
3651
3652/* ----------------------
3653 * Alter Statistics Statement
3654 * ----------------------
3655 */
3656typedef struct AlterStatsStmt
3657{
3659 List *defnames; /* qualified name (list of String) */
3660 Node *stxstattarget; /* statistics target */
3661 bool missing_ok; /* skip error if statistics object is missing */
3663
3664/* ----------------------
3665 * Create Function Statement
3666 * ----------------------
3667 */
3669{
3671 bool is_procedure; /* it's really CREATE PROCEDURE */
3672 bool replace; /* T => replace if already exists */
3673 List *funcname; /* qualified name of function to create */
3674 List *parameters; /* a list of FunctionParameter */
3675 TypeName *returnType; /* the return type */
3676 List *options; /* a list of DefElem */
3679
3681{
3682 /* the assigned enum values appear in pg_proc, don't change 'em! */
3683 FUNC_PARAM_IN = 'i', /* input only */
3684 FUNC_PARAM_OUT = 'o', /* output only */
3685 FUNC_PARAM_INOUT = 'b', /* both */
3686 FUNC_PARAM_VARIADIC = 'v', /* variadic (always input) */
3687 FUNC_PARAM_TABLE = 't', /* table function output column */
3688 /* this is not used in pg_proc: */
3689 FUNC_PARAM_DEFAULT = 'd', /* default; effectively same as IN */
3691
3692typedef struct FunctionParameter
3693{
3695 char *name; /* parameter name, or NULL if not given */
3696 TypeName *argType; /* TypeName for parameter type */
3697 FunctionParameterMode mode; /* IN/OUT/etc */
3698 Node *defexpr; /* raw default expr, or NULL if not given */
3699 ParseLoc location; /* token location, or -1 if unknown */
3701
3702typedef struct AlterFunctionStmt
3703{
3706 ObjectWithArgs *func; /* name and args of function */
3707 List *actions; /* list of DefElem */
3709
3710/* ----------------------
3711 * DO Statement
3712 *
3713 * DoStmt is the raw parser output, InlineCodeBlock is the execution-time API
3714 * ----------------------
3715 */
3716typedef struct DoStmt
3717{
3719 List *args; /* List of DefElem nodes */
3721
3722typedef struct InlineCodeBlock
3723{
3724 pg_node_attr(nodetag_only) /* this is not a member of parse trees */
3725
3726 NodeTag type;
3727 char *source_text; /* source text of anonymous code block */
3728 Oid langOid; /* OID of selected language */
3729 bool langIsTrusted; /* trusted property of the language */
3730 bool atomic; /* atomic execution context */
3732
3733/* ----------------------
3734 * CALL statement
3735 *
3736 * OUT-mode arguments are removed from the transformed funcexpr. The outargs
3737 * list contains copies of the expressions for all output arguments, in the
3738 * order of the procedure's declared arguments. (outargs is never evaluated,
3739 * but is useful to the caller as a reference for what to assign to.)
3740 * ----------------------
3741 */
3742typedef struct CallStmt
3743{
3745 /* from the parser */
3747 /* transformed call, with only input args */
3749 /* transformed output-argument expressions */
3752
3753typedef struct CallContext
3754{
3755 pg_node_attr(nodetag_only) /* this is not a member of parse trees */
3756
3757 NodeTag type;
3760
3761/* ----------------------
3762 * Alter Object Rename Statement
3763 * ----------------------
3764 */
3765typedef struct RenameStmt
3766{
3768 ObjectType renameType; /* OBJECT_TABLE, OBJECT_COLUMN, etc */
3769 ObjectType relationType; /* if column name, associated relation type */
3770 RangeVar *relation; /* in case it's a table */
3771 Node *object; /* in case it's some other object */
3772 char *subname; /* name of contained object (column, rule,
3773 * trigger, etc) */
3774 char *newname; /* the new name */
3775 DropBehavior behavior; /* RESTRICT or CASCADE behavior */
3776 bool missing_ok; /* skip error if missing? */
3778
3779/* ----------------------
3780 * ALTER object DEPENDS ON EXTENSION extname
3781 * ----------------------
3782 */
3784{
3786 ObjectType objectType; /* OBJECT_FUNCTION, OBJECT_TRIGGER, etc */
3787 RangeVar *relation; /* in case a table is involved */
3788 Node *object; /* name of the object */
3789 String *extname; /* extension name */
3790 bool remove; /* set true to remove dep rather than add */
3792
3793/* ----------------------
3794 * ALTER object SET SCHEMA Statement
3795 * ----------------------
3796 */
3798{
3800 ObjectType objectType; /* OBJECT_TABLE, OBJECT_TYPE, etc */
3801 RangeVar *relation; /* in case it's a table */
3802 Node *object; /* in case it's some other object */
3803 char *newschema; /* the new schema */
3804 bool missing_ok; /* skip error if missing? */
3806
3807/* ----------------------
3808 * Alter Object Owner Statement
3809 * ----------------------
3810 */
3811typedef struct AlterOwnerStmt
3812{
3814 ObjectType objectType; /* OBJECT_TABLE, OBJECT_TYPE, etc */
3815 RangeVar *relation; /* in case it's a table */
3816 Node *object; /* in case it's some other object */
3817 RoleSpec *newowner; /* the new owner */
3819
3820/* ----------------------
3821 * Alter Operator Set ( this-n-that )
3822 * ----------------------
3823 */
3824typedef struct AlterOperatorStmt
3825{
3827 ObjectWithArgs *opername; /* operator name and argument types */
3828 List *options; /* List of DefElem nodes */
3830
3831/* ------------------------
3832 * Alter Type Set ( this-n-that )
3833 * ------------------------
3834 */
3835typedef struct AlterTypeStmt
3836{
3838 List *typeName; /* type name (possibly qualified) */
3839 List *options; /* List of DefElem nodes */
3841
3842/* ----------------------
3843 * Create Rule Statement
3844 * ----------------------
3845 */
3846typedef struct RuleStmt
3847{
3849 RangeVar *relation; /* relation the rule is for */
3850 char *rulename; /* name of the rule */
3851 Node *whereClause; /* qualifications */
3852 CmdType event; /* SELECT, INSERT, etc */
3853 bool instead; /* is a 'do instead'? */
3854 List *actions; /* the action statements */
3855 bool replace; /* OR REPLACE */
3857
3858/* ----------------------
3859 * Notify Statement
3860 * ----------------------
3861 */
3862typedef struct NotifyStmt
3863{
3865 char *conditionname; /* condition name to notify */
3866 char *payload; /* the payload string, or NULL if none */
3868
3869/* ----------------------
3870 * Listen Statement
3871 * ----------------------
3872 */
3873typedef struct ListenStmt
3874{
3876 char *conditionname; /* condition name to listen on */
3878
3879/* ----------------------
3880 * Unlisten Statement
3881 * ----------------------
3882 */
3883typedef struct UnlistenStmt
3884{
3886 char *conditionname; /* name to unlisten on, or NULL for all */
3888
3889/* ----------------------
3890 * {Begin|Commit|Rollback} Transaction Statement
3891 * ----------------------
3892 */
3906
3907typedef struct TransactionStmt
3908{
3910 TransactionStmtKind kind; /* see above */
3911 List *options; /* for BEGIN/START commands */
3912 /* for savepoint commands */
3914 /* for two-phase-commit related commands */
3916 bool chain; /* AND CHAIN option */
3917 /* token location, or -1 if unknown */
3920
3921/* ----------------------
3922 * Create Type Statement, composite types
3923 * ----------------------
3924 */
3925typedef struct CompositeTypeStmt
3926{
3928 RangeVar *typevar; /* the composite type to be created */
3929 List *coldeflist; /* list of ColumnDef nodes */
3931
3932/* ----------------------
3933 * Create Type Statement, enum types
3934 * ----------------------
3935 */
3936typedef struct CreateEnumStmt
3937{
3939 List *typeName; /* qualified name (list of String) */
3940 List *vals; /* enum values (list of String) */
3942
3943/* ----------------------
3944 * Create Type Statement, range types
3945 * ----------------------
3946 */
3947typedef struct CreateRangeStmt
3948{
3950 List *typeName; /* qualified name (list of String) */
3951 List *params; /* range parameters (list of DefElem) */
3953
3954/* ----------------------
3955 * Alter Type Statement, enum types
3956 * ----------------------
3957 */
3958typedef struct AlterEnumStmt
3959{
3961 List *typeName; /* qualified name (list of String) */
3962 char *oldVal; /* old enum value's name, if renaming */
3963 char *newVal; /* new enum value's name */
3964 char *newValNeighbor; /* neighboring enum value, if specified */
3965 bool newValIsAfter; /* place new enum value after neighbor? */
3966 bool skipIfNewValExists; /* no error if new already exists? */
3968
3969/* ----------------------
3970 * Create View Statement
3971 * ----------------------
3972 */
3979
3980typedef struct ViewStmt
3981{
3983 RangeVar *view; /* the view to be created */
3984 List *aliases; /* target column names */
3985 Node *query; /* the SELECT query (as a raw parse tree) */
3986 bool replace; /* replace an existing view? */
3987 List *options; /* options from WITH clause */
3988 ViewCheckOption withCheckOption; /* WITH CHECK OPTION */
3990
3991/* ----------------------
3992 * Load Statement
3993 * ----------------------
3994 */
3995typedef struct LoadStmt
3996{
3998 char *filename; /* file to load */
4000
4001/* ----------------------
4002 * Createdb Statement
4003 * ----------------------
4004 */
4005typedef struct CreatedbStmt
4006{
4008 char *dbname; /* name of database to create */
4009 List *options; /* List of DefElem nodes */
4011
4012/* ----------------------
4013 * Alter Database
4014 * ----------------------
4015 */
4016typedef struct AlterDatabaseStmt
4017{
4019 char *dbname; /* name of database to alter */
4020 List *options; /* List of DefElem nodes */
4022
4028
4030{
4032 char *dbname; /* database name */
4033 VariableSetStmt *setstmt; /* SET or RESET subcommand */
4035
4036/* ----------------------
4037 * Dropdb Statement
4038 * ----------------------
4039 */
4040typedef struct DropdbStmt
4041{
4043 char *dbname; /* database to drop */
4044 bool missing_ok; /* skip error if db is missing? */
4045 List *options; /* currently only FORCE is supported */
4047
4048/* ----------------------
4049 * Alter System Statement
4050 * ----------------------
4051 */
4057
4058/* ----------------------
4059 * Vacuum and Analyze Statements
4060 *
4061 * Even though these are nominally two statements, it's convenient to use
4062 * just one node type for both.
4063 * ----------------------
4064 */
4065typedef struct VacuumStmt
4066{
4068 List *options; /* list of DefElem nodes */
4069 List *rels; /* list of VacuumRelation, or NIL for all */
4070 bool is_vacuumcmd; /* true for VACUUM, false otherwise */
4072
4073/*
4074 * Info about a single target table of VACUUM/ANALYZE.
4075 *
4076 * If the OID field is set, it always identifies the table to process.
4077 * Then the relation field can be NULL; if it isn't, it's used only to report
4078 * failure to open/lock the relation.
4079 */
4080typedef struct VacuumRelation
4081{
4083 RangeVar *relation; /* table name to process, or NULL */
4084 Oid oid; /* table's OID; InvalidOid if not looked up */
4085 List *va_cols; /* list of column names, or NIL for all */
4087
4088/* ----------------------
4089 * Repack Statement
4090 * ----------------------
4091 */
4098
4099typedef struct RepackStmt
4100{
4102 RepackCommand command; /* type of command being run */
4103 VacuumRelation *relation; /* relation being repacked */
4104 char *indexname; /* order tuples by this index */
4105 bool usingindex; /* whether USING INDEX is specified */
4106 List *params; /* list of DefElem nodes */
4108
4109/* ----------------------
4110 * Explain Statement
4111 *
4112 * The "query" field is initially a raw parse tree, and is converted to a
4113 * Query node during parse analysis. Note that rewriting and planning
4114 * of the query are always postponed until execution.
4115 * ----------------------
4116 */
4117typedef struct ExplainStmt
4118{
4120 Node *query; /* the query (see comments above) */
4121 List *options; /* list of DefElem nodes */
4123
4124/* ----------------------
4125 * CREATE TABLE AS Statement (a/k/a SELECT INTO)
4126 *
4127 * A query written as CREATE TABLE AS will produce this node type natively.
4128 * A query written as SELECT ... INTO will be transformed to this form during
4129 * parse analysis.
4130 * A query written as CREATE MATERIALIZED view will produce this node type,
4131 * during parse analysis, since it needs all the same data.
4132 *
4133 * The "query" field is handled similarly to EXPLAIN, though note that it
4134 * can be a SELECT or an EXECUTE, but not other DML statements.
4135 * ----------------------
4136 */
4137typedef struct CreateTableAsStmt
4138{
4140 Node *query; /* the query (see comments above) */
4141 IntoClause *into; /* destination table */
4142 ObjectType objtype; /* OBJECT_TABLE or OBJECT_MATVIEW */
4143 bool is_select_into; /* it was written as SELECT INTO */
4144 bool if_not_exists; /* just do nothing if it already exists? */
4146
4147/* ----------------------
4148 * REFRESH MATERIALIZED VIEW Statement
4149 * ----------------------
4150 */
4152{
4154 bool concurrent; /* allow concurrent access? */
4155 bool skipData; /* true for WITH NO DATA */
4156 RangeVar *relation; /* relation to insert into */
4158
4159/* ----------------------
4160 * Checkpoint Statement
4161 * ----------------------
4162 */
4163typedef struct CheckPointStmt
4164{
4166 List *options; /* list of DefElem nodes */
4168
4169/* ----------------------
4170 * Discard Statement
4171 * ----------------------
4172 */
4173
4181
4187
4188/* ----------------------
4189 * LOCK Statement
4190 * ----------------------
4191 */
4192typedef struct LockStmt
4193{
4195 List *relations; /* relations to lock */
4196 int mode; /* lock mode */
4197 bool nowait; /* no wait mode */
4199
4200/* ----------------------
4201 * SET CONSTRAINTS Statement
4202 * ----------------------
4203 */
4205{
4207 List *constraints; /* List of names as RangeVars */
4210
4211/* ----------------------
4212 * REINDEX Statement
4213 * ----------------------
4214 */
4216{
4218 REINDEX_OBJECT_TABLE, /* table or materialized view */
4220 REINDEX_OBJECT_SYSTEM, /* system catalogs */
4223
4224typedef struct ReindexStmt
4225{
4227 ReindexObjectType kind; /* REINDEX_OBJECT_INDEX, REINDEX_OBJECT_TABLE,
4228 * etc. */
4229 RangeVar *relation; /* Table or index to reindex */
4230 const char *name; /* name of database to reindex */
4231 List *params; /* list of DefElem nodes */
4233
4234/* ----------------------
4235 * CREATE CONVERSION Statement
4236 * ----------------------
4237 */
4239{
4241 List *conversion_name; /* Name of the conversion */
4242 char *for_encoding_name; /* source encoding name */
4243 char *to_encoding_name; /* destination encoding name */
4244 List *func_name; /* qualified conversion function name */
4245 bool def; /* is this a default conversion? */
4247
4248/* ----------------------
4249 * CREATE CAST Statement
4250 * ----------------------
4251 */
4261
4262/* ----------------------
4263 * CREATE PROPERTY GRAPH Statement
4264 * ----------------------
4265 */
4273
4282
4297
4305
4313
4314/* ----------------------
4315 * ALTER PROPERTY GRAPH Statement
4316 * ----------------------
4317 */
4318
4324
4343
4344/* ----------------------
4345 * CREATE TRANSFORM Statement
4346 * ----------------------
4347 */
4357
4358/* ----------------------
4359 * PREPARE Statement
4360 * ----------------------
4361 */
4362typedef struct PrepareStmt
4363{
4365 char *name; /* Name of plan, arbitrary */
4366 List *argtypes; /* Types of parameters (List of TypeName) */
4367 Node *query; /* The query itself (as a raw parsetree) */
4369
4370
4371/* ----------------------
4372 * EXECUTE Statement
4373 * ----------------------
4374 */
4375
4376typedef struct ExecuteStmt
4377{
4379 char *name; /* The name of the plan to execute */
4380 List *params; /* Values to assign to parameters */
4382
4383
4384/* ----------------------
4385 * DEALLOCATE Statement
4386 * ----------------------
4387 */
4388typedef struct DeallocateStmt
4389{
4391 /* The name of the plan to remove, NULL if DEALLOCATE ALL */
4393
4394 /*
4395 * True if DEALLOCATE ALL. This is redundant with "name == NULL", but we
4396 * make it a separate field so that exactly this condition (and not the
4397 * precise name) will be accounted for in query jumbling.
4398 */
4399 bool isall;
4400 /* token location, or -1 if unknown */
4403
4404/*
4405 * DROP OWNED statement
4406 */
4413
4414/*
4415 * REASSIGN OWNED statement
4416 */
4423
4424/*
4425 * TS Dictionary stmts: DefineStmt, RenameStmt and DropStmt are default
4426 */
4428{
4430 List *dictname; /* qualified name (list of String) */
4431 List *options; /* List of DefElem nodes */
4433
4434/*
4435 * TS Configuration stmts: DefineStmt, RenameStmt and DropStmt are default
4436 */
4445
4447{
4449 AlterTSConfigType kind; /* ALTER_TSCONFIG_ADD_MAPPING, etc */
4450 List *cfgname; /* qualified name (list of String) */
4451
4452 /*
4453 * dicts will be non-NIL if ADD/ALTER MAPPING was specified. If dicts is
4454 * NIL, but tokentype isn't, DROP MAPPING was specified.
4455 */
4456 List *tokentype; /* list of String */
4457 List *dicts; /* list of list of String */
4458 bool override; /* if true - remove old variant */
4459 bool replace; /* if true - replace dictionary by another */
4460 bool missing_ok; /* for DROP - skip error if missing? */
4462
4463typedef struct PublicationTable
4464{
4466 RangeVar *relation; /* publication relation */
4467 Node *whereClause; /* qualifications */
4468 List *columns; /* List of columns in a publication table */
4469 bool except; /* True if listed in the EXCEPT clause */
4471
4472/*
4473 * Publication object type
4474 */
4476{
4478 PUBLICATIONOBJ_EXCEPT_TABLE, /* A table in the EXCEPT clause */
4479 PUBLICATIONOBJ_TABLES_IN_SCHEMA, /* All tables in schema */
4480 PUBLICATIONOBJ_TABLES_IN_CUR_SCHEMA, /* All tables in first element of
4481 * search_path */
4482 PUBLICATIONOBJ_CONTINUATION, /* Continuation of previous type */
4484
4486{
4488 PublicationObjSpecType pubobjtype; /* type of this publication object */
4489 char *name;
4491 ParseLoc location; /* token location, or -1 if unknown */
4493
4494/*
4495 * Types of objects supported by FOR ALL publications
4496 */
4502
4504{
4506 PublicationAllObjType pubobjtype; /* type of this publication object */
4507 List *except_tables; /* tables specified in the EXCEPT clause */
4508 ParseLoc location; /* token location, or -1 if unknown */
4510
4512{
4514 char *pubname; /* Name of the publication */
4515 List *options; /* List of DefElem nodes */
4516 List *pubobjects; /* Optional list of publication objects */
4517 bool for_all_tables; /* Special publication for all tables in db */
4518 bool for_all_sequences; /* Special publication for all sequences
4519 * in db */
4521
4523{
4524 AP_AddObjects, /* add objects to publication */
4525 AP_DropObjects, /* remove objects from publication */
4526 AP_SetObjects, /* set list of objects */
4528
4530{
4532 char *pubname; /* Name of the publication */
4533
4534 /* parameters used for ALTER PUBLICATION ... WITH */
4535 List *options; /* List of DefElem nodes */
4536
4537 /*
4538 * Parameters used for ALTER PUBLICATION ... ADD/DROP/SET publication
4539 * objects.
4540 */
4541 List *pubobjects; /* Optional list of publication objects */
4542 AlterPublicationAction action; /* What action to perform with the given
4543 * objects */
4544 bool for_all_tables; /* True if ALL TABLES is specified */
4545 bool for_all_sequences; /* True if ALL SEQUENCES is specified */
4547
4549{
4551 char *subname; /* Name of the subscription */
4552 char *servername; /* Server name of publisher */
4553 char *conninfo; /* Connection string to publisher */
4554 List *publication; /* One or more publication to subscribe to */
4555 List *options; /* List of DefElem nodes */
4557
4571
4573{
4575 AlterSubscriptionType kind; /* ALTER_SUBSCRIPTION_OPTIONS, etc */
4576 char *subname; /* Name of the subscription */
4577 char *servername; /* Server name of publisher */
4578 char *conninfo; /* Connection string to publisher */
4579 List *publication; /* One or more publication to subscribe to */
4580 List *options; /* List of DefElem nodes */
4582
4584{
4586 char *subname; /* Name of the subscription */
4587 bool missing_ok; /* Skip error if missing? */
4588 DropBehavior behavior; /* RESTRICT or CASCADE behavior */
4590
4591typedef struct WaitStmt
4592{
4594 char *lsn_literal; /* LSN string from grammar */
4595 List *options; /* List of DefElem nodes */
4597
4598
4599#endif /* PARSENODES_H */
#define PG_INT32_MAX
Definition c.h:673
uint32 SubTransactionId
Definition c.h:740
int64_t int64
Definition c.h:621
int16_t int16
Definition c.h:619
int32_t int32
Definition c.h:620
uint64_t uint64
Definition c.h:625
uint32_t uint32
Definition c.h:624
unsigned int Index
Definition c.h:698
LockWaitPolicy
Definition lockoptions.h:38
LockClauseStrength
Definition lockoptions.h:22
OnConflictAction
Definition nodes.h:425
double Cardinality
Definition nodes.h:260
CmdType
Definition nodes.h:271
NodeTag
Definition nodes.h:27
LimitOption
Definition nodes.h:439
int ParseLoc
Definition nodes.h:248
JoinType
Definition nodes.h:296
RoleSpecType
Definition parsenodes.h:423
@ ROLESPEC_CURRENT_USER
Definition parsenodes.h:426
@ ROLESPEC_CSTRING
Definition parsenodes.h:424
@ ROLESPEC_SESSION_USER
Definition parsenodes.h:427
@ ROLESPEC_CURRENT_ROLE
Definition parsenodes.h:425
@ ROLESPEC_PUBLIC
Definition parsenodes.h:428
AlterSubscriptionType
@ ALTER_SUBSCRIPTION_REFRESH_PUBLICATION
@ ALTER_SUBSCRIPTION_ENABLED
@ ALTER_SUBSCRIPTION_DROP_PUBLICATION
@ ALTER_SUBSCRIPTION_SERVER
@ 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
RepackCommand
@ REPACK_COMMAND_REPACK
@ REPACK_COMMAND_CLUSTER
@ REPACK_COMMAND_VACUUMFULL
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:334
@ AEXPR_BETWEEN
Definition parsenodes.h:345
@ AEXPR_NULLIF
Definition parsenodes.h:340
@ AEXPR_NOT_DISTINCT
Definition parsenodes.h:339
@ AEXPR_BETWEEN_SYM
Definition parsenodes.h:347
@ AEXPR_NOT_BETWEEN_SYM
Definition parsenodes.h:348
@ AEXPR_ILIKE
Definition parsenodes.h:343
@ AEXPR_IN
Definition parsenodes.h:341
@ AEXPR_NOT_BETWEEN
Definition parsenodes.h:346
@ AEXPR_DISTINCT
Definition parsenodes.h:338
@ AEXPR_SIMILAR
Definition parsenodes.h:344
@ AEXPR_LIKE
Definition parsenodes.h:342
@ AEXPR_OP
Definition parsenodes.h:335
@ AEXPR_OP_ANY
Definition parsenodes.h:336
@ AEXPR_OP_ALL
Definition parsenodes.h:337
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_EXCEPT_TABLE
@ PUBLICATIONOBJ_CONTINUATION
PartitionStrategy
Definition parsenodes.h:918
@ PARTITION_STRATEGY_HASH
Definition parsenodes.h:921
@ PARTITION_STRATEGY_LIST
Definition parsenodes.h:919
@ PARTITION_STRATEGY_RANGE
Definition parsenodes.h:920
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_GRAPH_TABLE
@ RTE_RELATION
DefElemAction
Definition parsenodes.h:851
@ DEFELEM_UNSPEC
Definition parsenodes.h:852
@ DEFELEM_DROP
Definition parsenodes.h:855
@ DEFELEM_SET
Definition parsenodes.h:853
@ DEFELEM_ADD
Definition parsenodes.h:854
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:970
@ PARTITION_RANGE_DATUM_MAXVALUE
Definition parsenodes.h:973
@ PARTITION_RANGE_DATUM_VALUE
Definition parsenodes.h:972
@ PARTITION_RANGE_DATUM_MINVALUE
Definition parsenodes.h:971
GraphElementPatternKind
@ EDGE_PATTERN_RIGHT
@ VERTEX_PATTERN
@ EDGE_PATTERN_LEFT
@ PAREN_EXPR
@ EDGE_PATTERN_ANY
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_PROPGRAPH
@ 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
AlterPropGraphElementKind
@ PROPGRAPH_ELEMENT_KIND_EDGE
@ PROPGRAPH_ELEMENT_KIND_VERTEX
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:806
@ CREATE_TABLE_LIKE_COMMENTS
Definition parsenodes.h:807
@ CREATE_TABLE_LIKE_GENERATED
Definition parsenodes.h:811
@ CREATE_TABLE_LIKE_IDENTITY
Definition parsenodes.h:812
@ CREATE_TABLE_LIKE_COMPRESSION
Definition parsenodes.h:808
@ CREATE_TABLE_LIKE_STORAGE
Definition parsenodes.h:815
@ CREATE_TABLE_LIKE_ALL
Definition parsenodes.h:816
@ CREATE_TABLE_LIKE_INDEXES
Definition parsenodes.h:813
@ CREATE_TABLE_LIKE_DEFAULTS
Definition parsenodes.h:810
@ CREATE_TABLE_LIKE_STATISTICS
Definition parsenodes.h:814
@ CREATE_TABLE_LIKE_CONSTRAINTS
Definition parsenodes.h:809
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:1599
JsonWrapper
Definition primnodes.h:1770
OnCommitAction
Definition primnodes.h:58
JsonExprOp
Definition primnodes.h:1822
CoercionForm
Definition primnodes.h:756
OverridingKind
Definition primnodes.h:28
MergeMatchKind
Definition primnodes.h:2016
CoercionContext
Definition primnodes.h:736
Oid RelFileNumber
Definition relpath.h:25
NodeTag type
Definition parsenodes.h:522
List * elements
Definition parsenodes.h:523
ParseLoc list_start
Definition parsenodes.h:524
ParseLoc list_end
Definition parsenodes.h:525
ParseLoc location
Definition parsenodes.h:526
bool isnull
Definition parsenodes.h:393
union ValUnion val
Definition parsenodes.h:392
ParseLoc location
Definition parsenodes.h:394
pg_node_attr(custom_copy_equal, custom_read_write, custom_query_jumble) NodeTag type
ParseLoc location
Definition parsenodes.h:368
ParseLoc rexpr_list_end
Definition parsenodes.h:367
Node * lexpr
Definition parsenodes.h:358
ParseLoc rexpr_list_start
Definition parsenodes.h:366
pg_node_attr(custom_read_write) NodeTag type
List * name
Definition parsenodes.h:357
A_Expr_Kind kind
Definition parsenodes.h:356
Node * rexpr
Definition parsenodes.h:359
bool is_slice
Definition parsenodes.h:490
Node * uidx
Definition parsenodes.h:492
NodeTag type
Definition parsenodes.h:489
Node * lidx
Definition parsenodes.h:491
List * indirection
Definition parsenodes.h:514
NodeTag type
Definition parsenodes.h:478
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
PropGraphProperties * add_properties
const char * alter_label
AlterPropGraphElementKind element_kind
DropBehavior drop_behavior
const char * element_alias
const char * drop_label
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)
List * collname
Definition parsenodes.h:415
ParseLoc location
Definition parsenodes.h:416
bool is_not_null
Definition parsenodes.h:777
CollateClause * collClause
Definition parsenodes.h:787
char identity
Definition parsenodes.h:783
RangeVar * identitySequence
Definition parsenodes.h:784
List * constraints
Definition parsenodes.h:789
Node * cooked_default
Definition parsenodes.h:782
char * storage_name
Definition parsenodes.h:780
char * colname
Definition parsenodes.h:772
TypeName * typeName
Definition parsenodes.h:773
char generated
Definition parsenodes.h:786
NodeTag type
Definition parsenodes.h:771
bool is_from_type
Definition parsenodes.h:778
List * fdwoptions
Definition parsenodes.h:790
Node * raw_default
Definition parsenodes.h:781
char storage
Definition parsenodes.h:779
bool is_local
Definition parsenodes.h:776
int16 inhcount
Definition parsenodes.h:775
char * compression
Definition parsenodes.h:774
ParseLoc location
Definition parsenodes.h:791
ParseLoc location
Definition parsenodes.h:317
List * fields
Definition parsenodes.h:316
NodeTag type
Definition parsenodes.h:315
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:861
NodeTag type
Definition parsenodes.h:860
DefElemAction defaction
Definition parsenodes.h:865
char * defname
Definition parsenodes.h:862
ParseLoc location
Definition parsenodes.h:866
Node * arg
Definition parsenodes.h:863
List * definition
List * defnames
List * args
NodeTag type
ObjectType kind
bool if_not_exists
ReturningClause * returningClause
WithClause * withClause
Node * whereClause
RangeVar * relation
List * usingClause
ForPortionOfClause * forPortionOf
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
ParseLoc target_location
bool agg_within_group
Definition parsenodes.h:462
CoercionForm funcformat
Definition parsenodes.h:466
Node * agg_filter
Definition parsenodes.h:459
List * agg_order
Definition parsenodes.h:458
List * funcname
Definition parsenodes.h:456
List * args
Definition parsenodes.h:457
bool agg_star
Definition parsenodes.h:463
int ignore_nulls
Definition parsenodes.h:461
bool agg_distinct
Definition parsenodes.h:464
NodeTag type
Definition parsenodes.h:455
ParseLoc location
Definition parsenodes.h:467
bool func_variadic
Definition parsenodes.h:465
struct WindowDef * over
Definition parsenodes.h:460
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
GraphElementPatternKind kind
const char * variable
Node * whereClause
List * path_pattern_list
NodeTag type
List * content
GroupingSetKind kind pg_node_attr(query_jumble_ignore)
ParseLoc location
ImportForeignSchemaType list_type
Node * expr
Definition parsenodes.h:830
SortByDir ordering
Definition parsenodes.h:835
List * opclassopts
Definition parsenodes.h:834
NodeTag type
Definition parsenodes.h:828
char * indexcolname
Definition parsenodes.h:831
ParseLoc location
Definition parsenodes.h:837
SortByNulls nulls_ordering
Definition parsenodes.h:836
List * opclass
Definition parsenodes.h:833
char * name
Definition parsenodes.h:829
List * collation
Definition parsenodes.h:832
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:881
LockClauseStrength strength
Definition parsenodes.h:882
LockWaitPolicy waitPolicy
Definition parsenodes.h:883
ReturningClause * returningClause
Node * sourceRelation
List * mergeWhenClauses
RangeVar * relation
Node * joinCondition
WithClause * withClause
NodeTag type
CmdType commandType
MergeMatchKind matchKind
Definition nodes.h:133
char * payload
char * conditionname
NodeTag type
InferClause * infer
OnConflictAction action
LockClauseStrength lockStrength
SelectStmt * val
ParseLoc location
List * indirection
ParseLoc location
Definition parsenodes.h:327
NodeTag type
Definition parsenodes.h:325
PartitionBoundSpec * bound
List * partlist
RangeVar * name
List * collation
Definition parsenodes.h:912
ParseLoc location
Definition parsenodes.h:914
PartitionRangeDatumKind kind
Definition parsenodes.h:980
List * partParams
Definition parsenodes.h:933
ParseLoc location
Definition parsenodes.h:934
PartitionStrategy strategy
Definition parsenodes.h:932
List * argtypes
NodeTag type
List * edestvertexcols
char * esrcvertex
RangeVar * etable
char * edestvertex
ParseLoc location
List * esrcvertexcols
struct PropGraphProperties * properties
ParseLoc location
RangeVar * vtable
PublicationAllObjType pubobjtype
PublicationObjSpecType pubobjtype
PublicationTable * pubtable
RangeVar * relation
List * rowMarks
Definition parsenodes.h:239
int mergeTargetRelation pg_node_attr(query_jumble_ignore)
bool hasAggs pg_node_attr(query_jumble_ignore)
bool groupDistinct
Definition parsenodes.h:222
bool hasRecursive pg_node_attr(query_jumble_ignore)
Node * mergeJoinCondition
Definition parsenodes.h:201
Node * limitCount
Definition parsenodes.h:236
FromExpr * jointree
Definition parsenodes.h:187
List * returningList
Definition parsenodes.h:219
bool canSetTag pg_node_attr(query_jumble_ignore)
Node * setOperations
Definition parsenodes.h:241
bool hasSubLinks pg_node_attr(query_jumble_ignore)
List * cteList
Definition parsenodes.h:178
OnConflictExpr * onConflict
Definition parsenodes.h:208
char *returningOldAlias pg_node_attr(query_jumble_ignore)
OverridingKind override pg_node_attr(query_jumble_ignore)
ForPortionOfExpr * forPortionOf
Definition parsenodes.h:153
List * groupClause
Definition parsenodes.h:221
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:227
List * rtable
Definition parsenodes.h:180
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:235
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:124
LimitOption limitOption
Definition parsenodes.h:237
Node * utilityStmt
Definition parsenodes.h:144
List * mergeActionList
Definition parsenodes.h:190
bool hasModifyingCTE pg_node_attr(query_jumble_ignore)
NodeTag type
Definition parsenodes.h:122
List * windowClause
Definition parsenodes.h:229
List * targetList
Definition parsenodes.h:203
List * groupingSets
Definition parsenodes.h:225
bool groupByAll
Definition parsenodes.h:223
List * distinctClause
Definition parsenodes.h:231
bool hasForUpdate pg_node_attr(query_jumble_ignore)
List * sortClause
Definition parsenodes.h:233
char *returningNewAlias pg_node_attr(query_jumble_ignore)
ParseLoc stmt_location
Definition parsenodes.h:260
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:677
List * coldeflist
Definition parsenodes.h:678
List * functions
Definition parsenodes.h:676
struct GraphPattern * graph_pattern
Definition parsenodes.h:725
ParseLoc location
Definition parsenodes.h:728
RangeVar * graph_name
Definition parsenodes.h:724
TypeName * typeName
Definition parsenodes.h:710
List * namespaces
Definition parsenodes.h:694
ParseLoc location
Definition parsenodes.h:697
ParseLoc location
Definition parsenodes.h:748
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)
List * graph_table_columns
int joinmergedcols pg_node_attr(query_jumble_ignore)
GraphPattern * graph_pattern
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
bool usingindex
NodeTag type
VacuumRelation * relation
List * params
char * indexname
RepackCommand command
Node * val
Definition parsenodes.h:552
ParseLoc location
Definition parsenodes.h:553
List * indirection
Definition parsenodes.h:551
char * name
Definition parsenodes.h:550
NodeTag type
Definition parsenodes.h:549
NodeTag type
Node * returnval
ReturningOptionKind option
ParseLoc location
ParseLoc location
Definition parsenodes.h:436
RoleSpecType roletype
Definition parsenodes.h:434
NodeTag type
Definition parsenodes.h:433
char * rolename
Definition parsenodes.h:435
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:996
SortByNulls sortby_nulls
Definition parsenodes.h:581
Node * node
Definition parsenodes.h:579
NodeTag type
Definition parsenodes.h:578
List * useOp
Definition parsenodes.h:582
SortByDir sortby_dir
Definition parsenodes.h:580
ParseLoc location
Definition parsenodes.h:583
bool hashable pg_node_attr(query_jumble_ignore)
NodeTag type
char * name
Node * expr
Definition value.h:64
RangeVar * relation
Definition parsenodes.h:800
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:404
ParseLoc location
Definition parsenodes.h:405
Node * arg
Definition parsenodes.h:403
NodeTag type
Definition parsenodes.h:402
bool setof
Definition parsenodes.h:292
Oid typeOid
Definition parsenodes.h:291
bool pct_type
Definition parsenodes.h:293
List * names
Definition parsenodes.h:290
NodeTag type
Definition parsenodes.h:289
List * arrayBounds
Definition parsenodes.h:296
int32 typemod
Definition parsenodes.h:295
ParseLoc location
Definition parsenodes.h:297
List * typmods
Definition parsenodes.h:294
char * conditionname
List * targetList
ForPortionOfClause * forPortionOf
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:600
ParseLoc location
Definition parsenodes.h:604
NodeTag type
Definition parsenodes.h:596
List * partitionClause
Definition parsenodes.h:599
Node * startOffset
Definition parsenodes.h:602
char * refname
Definition parsenodes.h:598
Node * endOffset
Definition parsenodes.h:603
int frameOptions
Definition parsenodes.h:601
char * name
Definition parsenodes.h:597
List * ctes
NodeTag type
ParseLoc location
ParseLoc location
Definition parsenodes.h:896
TypeName * typeName
Definition parsenodes.h:894
NodeTag type
Definition parsenodes.h:891
XmlOptionType xmloption
Definition parsenodes.h:892
BitString bsval
Definition parsenodes.h:384
Node node
Definition parsenodes.h:379
Float fval
Definition parsenodes.h:381
String sval
Definition parsenodes.h:383
Boolean boolval
Definition parsenodes.h:382
Integer ival
Definition parsenodes.h:380
const char * type
const char * name