mirror of
https://github.com/postgres/postgres.git
synced 2026-02-03 20:40:14 -05:00
These clauses allow the user to specify how data from nested paths are joined, allowing considerable freedom in shaping the tabular output of JSON_TABLE. PLAN DEFAULT allows the user to specify the global strategies when dealing with sibling or child nested paths. The is often sufficient to achieve the necessary goal, and is considerably simpler than the full PLAN clause, which allows the user to specify the strategy to be used for each named nested path. Nikita Glukhov Reviewers have included (in no particular order) Andres Freund, Alexander Korotkov, Pavel Stehule, Andrew Alsup, Erik Rijkers, Zhihong Yu, Himanshu Upadhyaya, Daniel Gustafsson, Justin Pryzby. Discussion: https://postgr.es/m/7e2cb85d-24cf-4abb-30a5-1a33715959bd@postgrespro.ru
121 lines
4 KiB
C
121 lines
4 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* makefuncs.h
|
|
* prototypes for the creator functions of various nodes
|
|
*
|
|
*
|
|
* Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*
|
|
* src/include/nodes/makefuncs.h
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef MAKEFUNC_H
|
|
#define MAKEFUNC_H
|
|
|
|
#include "nodes/execnodes.h"
|
|
#include "nodes/parsenodes.h"
|
|
|
|
|
|
extern A_Expr *makeA_Expr(A_Expr_Kind kind, List *name,
|
|
Node *lexpr, Node *rexpr, int location);
|
|
|
|
extern A_Expr *makeSimpleA_Expr(A_Expr_Kind kind, char *name,
|
|
Node *lexpr, Node *rexpr, int location);
|
|
|
|
extern Var *makeVar(int varno,
|
|
AttrNumber varattno,
|
|
Oid vartype,
|
|
int32 vartypmod,
|
|
Oid varcollid,
|
|
Index varlevelsup);
|
|
|
|
extern Var *makeVarFromTargetEntry(int varno,
|
|
TargetEntry *tle);
|
|
|
|
extern Var *makeWholeRowVar(RangeTblEntry *rte,
|
|
int varno,
|
|
Index varlevelsup,
|
|
bool allowScalar);
|
|
|
|
extern TargetEntry *makeTargetEntry(Expr *expr,
|
|
AttrNumber resno,
|
|
char *resname,
|
|
bool resjunk);
|
|
|
|
extern TargetEntry *flatCopyTargetEntry(TargetEntry *src_tle);
|
|
|
|
extern FromExpr *makeFromExpr(List *fromlist, Node *quals);
|
|
|
|
extern Const *makeConst(Oid consttype,
|
|
int32 consttypmod,
|
|
Oid constcollid,
|
|
int constlen,
|
|
Datum constvalue,
|
|
bool constisnull,
|
|
bool constbyval);
|
|
|
|
extern Const *makeNullConst(Oid consttype, int32 consttypmod, Oid constcollid);
|
|
|
|
extern Node *makeBoolConst(bool value, bool isnull);
|
|
|
|
extern Expr *makeBoolExpr(BoolExprType boolop, List *args, int location);
|
|
|
|
extern Alias *makeAlias(const char *aliasname, List *colnames);
|
|
|
|
extern RelabelType *makeRelabelType(Expr *arg, Oid rtype, int32 rtypmod,
|
|
Oid rcollid, CoercionForm rformat);
|
|
|
|
extern RangeVar *makeRangeVar(char *schemaname, char *relname, int location);
|
|
|
|
extern TypeName *makeTypeName(char *typnam);
|
|
extern TypeName *makeTypeNameFromNameList(List *names);
|
|
extern TypeName *makeTypeNameFromOid(Oid typeOid, int32 typmod);
|
|
|
|
extern ColumnDef *makeColumnDef(const char *colname,
|
|
Oid typeOid, int32 typmod, Oid collOid);
|
|
|
|
extern FuncExpr *makeFuncExpr(Oid funcid, Oid rettype, List *args,
|
|
Oid funccollid, Oid inputcollid, CoercionForm fformat);
|
|
|
|
extern FuncCall *makeFuncCall(List *name, List *args,
|
|
CoercionForm funcformat, int location);
|
|
|
|
extern Expr *make_opclause(Oid opno, Oid opresulttype, bool opretset,
|
|
Expr *leftop, Expr *rightop,
|
|
Oid opcollid, Oid inputcollid);
|
|
|
|
extern Expr *make_andclause(List *andclauses);
|
|
extern Expr *make_orclause(List *orclauses);
|
|
extern Expr *make_notclause(Expr *notclause);
|
|
|
|
extern Node *make_and_qual(Node *qual1, Node *qual2);
|
|
extern Expr *make_ands_explicit(List *andclauses);
|
|
extern List *make_ands_implicit(Expr *clause);
|
|
|
|
extern IndexInfo *makeIndexInfo(int numattrs, int numkeyattrs, Oid amoid,
|
|
List *expressions, List *predicates,
|
|
bool unique, bool nulls_not_distinct, bool isready, bool concurrent);
|
|
|
|
extern DefElem *makeDefElem(char *name, Node *arg, int location);
|
|
extern DefElem *makeDefElemExtended(char *nameSpace, char *name, Node *arg,
|
|
DefElemAction defaction, int location);
|
|
|
|
extern GroupingSet *makeGroupingSet(GroupingSetKind kind, List *content, int location);
|
|
|
|
extern VacuumRelation *makeVacuumRelation(RangeVar *relation, Oid oid, List *va_cols);
|
|
|
|
extern JsonFormat *makeJsonFormat(JsonFormatType type, JsonEncoding encoding,
|
|
int location);
|
|
extern JsonValueExpr *makeJsonValueExpr(Expr *expr, JsonFormat *format);
|
|
extern JsonBehavior *makeJsonBehavior(JsonBehaviorType type, Node *expr);
|
|
extern Node *makeJsonTableJoinedPlan(JsonTablePlanJoinType type,
|
|
Node *plan1, Node *plan2, int location);
|
|
extern Node *makeJsonKeyValue(Node *key, Node *value);
|
|
extern Node *makeJsonIsPredicate(Node *expr, JsonFormat *format,
|
|
JsonValueType vtype, bool unique_keys,
|
|
int location);
|
|
extern JsonEncoding makeJsonEncoding(char *name);
|
|
|
|
#endif /* MAKEFUNC_H */
|