36 Var *var,
int levelsup);
39 const char *targetName,
50 bool make_target_entry);
55 int sublevels_up,
int location,
56 bool make_target_entry);
58 bool make_target_entry);
97 if (colname == NULL && !resjunk)
135 foreach(o_target, targetlist)
227 foreach(lc, exprlist)
293 foreach(l, targetlist)
298 if (restype == UNKNOWNOID)
301 restype, TEXTOID, -1,
323 foreach(l, targetlist)
345 Var *var,
int levelsup)
351 if (var == NULL || !
IsA(var,
Var))
361 tle->resorigtbl = rte->
relid;
371 if (ste == NULL || ste->resjunk)
372 elog(
ERROR,
"subquery %s does not have attribute %d",
374 tle->resorigtbl = ste->resorigtbl;
375 tle->resorigcol = ste->resorigcol;
407 if (cte->search_clause)
409 if (cte->cycle_clause)
417 if (ste == NULL || ste->resjunk)
418 elog(
ERROR,
"CTE %s does not have attribute %d",
420 tle->resorigtbl = ste->resorigtbl;
421 tle->resorigcol = ste->resorigcol;
480 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
481 errmsg(
"cannot assign to system column \"%s\"",
502 def->typeMod = attrtypmod;
503 def->collation = attrcollation;
508 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
509 errmsg(
"cannot set an array element to DEFAULT"),
513 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
514 errmsg(
"cannot set a subfield to DEFAULT"),
550 attrtype, attrtypmod, attrcollation, 0);
553 colVar = (
Node *) var;
581 attrtype, attrtypmod,
587 (
errcode(ERRCODE_DATATYPE_MISMATCH),
588 errmsg(
"column \"%s\" is of type %s"
589 " but expression is of type %s",
593 errhint(
"You will need to rewrite or cast the expression."),
643 tle->resname = colname;
686 const char *targetName,
687 bool targetIsSubscripting,
701 if (indirection_cell && !basenode)
712 ctest->
typeId = targetTypeId;
713 ctest->typeMod = targetTypMod;
714 ctest->collation = targetCollation;
715 basenode = (
Node *) ctest;
728 subscripts =
lappend(subscripts, n);
732 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
733 errmsg(
"row expansion via \"*\" is not supported here"),
773 baseTypeMod = targetTypMod;
779 (
errcode(ERRCODE_DATATYPE_MISMATCH),
780 errmsg(
"cannot assign to field \"%s\" of column \"%s\" because its type %s is not a composite type",
788 (
errcode(ERRCODE_UNDEFINED_COLUMN),
789 errmsg(
"cannot assign to field \"%s\" of column \"%s\" because there is no such column in data type %s",
795 (
errcode(ERRCODE_UNDEFINED_COLUMN),
796 errmsg(
"cannot assign to system column \"%s\"",
801 &fieldTypeId, &fieldTypMod, &fieldCollation);
819 fstore->
arg = (
Expr *) basenode;
822 fstore->resulttype = baseTypeId;
825 if (baseTypeId != targetTypeId)
827 baseTypeId, baseTypeMod,
834 return (
Node *) fstore;
860 targetTypeId, targetTypMod,
866 if (targetIsSubscripting)
868 (
errcode(ERRCODE_DATATYPE_MISMATCH),
869 errmsg(
"subscripted assignment to \"%s\" requires type %s"
870 " but expression is of type %s",
874 errhint(
"You will need to rewrite or cast the expression."),
878 (
errcode(ERRCODE_DATATYPE_MISMATCH),
879 errmsg(
"subfield \"%s\" is of type %s"
880 " but expression is of type %s",
884 errhint(
"You will need to rewrite or cast the expression."),
897 const char *targetName,
911 int32 containerTypMod;
919 containerType = targetTypeId;
920 containerTypMod = targetTypMod;
931 typeNeeded = sbsref->refrestype;
932 typmodNeeded = sbsref->reftypmod;
941 if (containerType == targetTypeId)
942 collationNeeded = targetCollation;
965 sbsref->refrestype = containerType;
966 sbsref->reftypmod = containerTypMod;
968 result = (
Node *) sbsref;
971 if (containerType != targetTypeId)
977 targetTypeId, targetTypMod,
984 (
errcode(ERRCODE_CANNOT_COERCE),
985 errmsg(
"cannot cast type %s to %s",
1015 for (
i = 0;
i < numcol;
i++)
1022 if (attr->attisdropped)
1053 (
errcode(ERRCODE_UNDEFINED_COLUMN),
1054 errmsg(
"column \"%s\" of relation \"%s\" does not exist",
1069 (
errcode(ERRCODE_DUPLICATE_COLUMN),
1070 errmsg(
"column \"%s\" specified more than once",
1080 (
errcode(ERRCODE_DUPLICATE_COLUMN),
1081 errmsg(
"column \"%s\" specified more than once",
1108 bool make_target_entry)
1123 Assert(make_target_entry);
1142 char *nspname = NULL;
1151 } crserr = CRSERR_NO_RTE;
1190 crserr = CRSERR_WRONG_DB;
1201 crserr = CRSERR_TOO_MANY;
1219 (
Node *) (nsitem ? nsitem->
p_rte : NULL));
1224 (
errcode(ERRCODE_AMBIGUOUS_COLUMN),
1225 errmsg(
"column reference \"%s\" is ambiguous",
1243 case CRSERR_WRONG_DB:
1245 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
1246 errmsg(
"cross-database references are not implemented: %s",
1250 case CRSERR_TOO_MANY:
1252 (
errcode(ERRCODE_SYNTAX_ERROR),
1253 errmsg(
"improper qualified name (too many dotted names): %s",
1283 bool found_table =
false;
1313 (
errcode(ERRCODE_SYNTAX_ERROR),
1314 errmsg(
"SELECT * with no tables specified is not valid"),
1360 int sublevels_up,
int location,
bool make_target_entry)
1362 if (make_target_entry)
1386 Assert(perminfo != NULL);
1411 bool make_target_entry)
1451 ((
Var *) expr)->vartype == RECORDOID)
1458 numAttrs = tupleDesc->
natts;
1459 for (
i = 0;
i < numAttrs;
i++)
1464 if (att->attisdropped)
1470 fselect->resulttype = att->atttypid;
1471 fselect->resulttypmod = att->atttypmod;
1473 fselect->resultcollid = att->attcollation;
1475 if (make_target_entry)
1487 result =
lappend(result, fselect);
1515 Assert(var->vartype == RECORDOID);
1555 Assert(lname == NULL && lvar == NULL);
1560 expr = (
Node *) var;
1581 if (ste == NULL || ste->resjunk)
1582 elog(
ERROR,
"subquery %s does not have attribute %d",
1634 if (ste == NULL || ste->resjunk)
1635 elog(
ERROR,
"CTE %s does not have attribute %d",
1649 MemSet(&mypstate, 0,
sizeof(mypstate));
1738 foreach(l, ((
ColumnRef *) node)->fields)
1752 case T_A_Indirection:
1759 foreach(l,
ind->indirection)
1790 if (((
TypeCast *) node)->typeName != NULL)
1797 case T_CollateClause:
1799 case T_GroupingFunc:
1804 switch (((
SubLink *) node)->subLinkType)
1831 *
name = te->resname;
1863 case T_CoalesceExpr:
1881 switch (((
XmlExpr *) node)->op)
1884 *
name =
"xmlconcat";
1887 *
name =
"xmlelement";
1890 *
name =
"xmlforest";
1902 *
name =
"xmlserialize";
1909 case T_XmlSerialize:
1911 *
name =
"xmlserialize";
1913 case T_JsonObjectConstructor:
1915 *
name =
"json_object";
1917 case T_JsonArrayConstructor:
1918 case T_JsonArrayQueryConstructor:
1920 *
name =
"json_array";
1922 case T_JsonObjectAgg:
1924 *
name =
"json_objectagg";
1926 case T_JsonArrayAgg:
1928 *
name =
"json_arrayagg";
#define InvalidAttrNumber
bool bms_is_member(int x, const Bitmapset *a)
Bitmapset * bms_add_member(Bitmapset *a, int x)
#define MemSet(start, val, len)
char * get_database_name(Oid dbid)
static void PGresult * res
elog(ERROR, "%s: %s", p2, msg)
int errhint(const char *fmt,...)
int errcode(int sqlerrcode)
int errmsg(const char *fmt,...)
#define ereport(elevel,...)
TupleDesc get_expr_result_tupdesc(Node *expr, bool noError)
if(TABLE==NULL||TABLE_index==NULL)
Assert(fmt[strlen(fmt) - 1] !='\n')
List * list_truncate(List *list, int new_size)
List * lappend(List *list, void *datum)
List * lappend_int(List *list, int datum)
List * list_concat(List *list1, const List *list2)
AttrNumber get_attnum(Oid relid, const char *attname)
Oid get_typcollation(Oid typid)
Oid getBaseTypeAndTypmod(Oid typid, int32 *typmod)
void get_atttypetypmodcoll(Oid relid, AttrNumber attnum, Oid *typid, int32 *typmod, Oid *collid)
TargetEntry * makeTargetEntry(Expr *expr, AttrNumber resno, char *resname, bool resjunk)
Const * makeNullConst(Oid consttype, int32 consttypmod, Oid constcollid)
RangeVar * makeRangeVar(char *schemaname, char *relname, int location)
Var * makeVar(int varno, AttrNumber varattno, Oid vartype, int32 vartypmod, Oid varcollid, Index varlevelsup)
char * pstrdup(const char *in)
char * NameListToString(List *names)
Oid exprType(const Node *expr)
int32 exprTypmod(const Node *expr)
Oid exprCollation(const Node *expr)
int exprLocation(const Node *expr)
#define IsA(nodeptr, _type_)
Node * coerce_type(ParseState *pstate, Node *node, Oid inputTypeId, Oid targetTypeId, int32 targetTypeMod, CoercionContext ccontext, CoercionForm cformat, int location)
Node * coerce_to_domain(Node *arg, Oid baseTypeId, int32 baseTypeMod, Oid typeId, CoercionContext ccontext, CoercionForm cformat, int location, bool hideInputCoercion)
Node * coerce_to_target_type(ParseState *pstate, Node *expr, Oid exprtype, Oid targettype, int32 targettypmod, CoercionContext ccontext, CoercionForm cformat, int location)
Node * transformExpr(ParseState *pstate, Node *expr, ParseExprKind exprKind)
SubscriptingRef * transformContainerSubscripts(ParseState *pstate, Node *containerBase, Oid containerType, int32 containerTypMod, List *indirection, bool isAssignment)
int parser_errposition(ParseState *pstate, int location)
void transformContainerType(Oid *containerType, int32 *containerTypmod)
@ EXPR_KIND_UPDATE_TARGET
@ EXPR_KIND_UPDATE_SOURCE
RangeTblEntry * GetRTEByRangeTablePosn(ParseState *pstate, int varno, int sublevels_up)
void markVarForSelectPriv(ParseState *pstate, Var *var)
void errorMissingRTE(ParseState *pstate, RangeVar *relation)
TargetEntry * get_tle_by_resno(List *tlist, AttrNumber resno)
ParseNamespaceItem * GetNSItemByRangeTablePosn(ParseState *pstate, int varno, int sublevels_up)
ParseNamespaceItem * refnameNamespaceItem(ParseState *pstate, const char *schemaname, const char *refname, int location, int *sublevels_up)
Oid attnumTypeId(Relation rd, int attid)
List * expandNSItemVars(ParseState *pstate, ParseNamespaceItem *nsitem, int sublevels_up, int location, List **colnames)
List * expandNSItemAttrs(ParseState *pstate, ParseNamespaceItem *nsitem, int sublevels_up, bool require_col_privs, int location)
void expandRTE(RangeTblEntry *rte, int rtindex, int sublevels_up, int location, bool include_dropped, List **colnames, List **colvars)
CommonTableExpr * GetCTEForRTE(ParseState *pstate, RangeTblEntry *rte, int rtelevelsup)
int attnameAttNum(Relation rd, const char *attname, bool sysColOK)
static List * ExpandColumnRefStar(ParseState *pstate, ColumnRef *cref, bool make_target_entry)
List * transformTargetList(ParseState *pstate, List *targetlist, ParseExprKind exprKind)
static int FigureColnameInternal(Node *node, char **name)
Expr * transformAssignedExpr(ParseState *pstate, Expr *expr, ParseExprKind exprKind, const char *colname, int attrno, List *indirection, int location)
static void markTargetListOrigin(ParseState *pstate, TargetEntry *tle, Var *var, int levelsup)
static List * ExpandSingleTable(ParseState *pstate, ParseNamespaceItem *nsitem, int sublevels_up, int location, bool make_target_entry)
char * FigureIndexColname(Node *node)
static Node * transformAssignmentSubscripts(ParseState *pstate, Node *basenode, const char *targetName, Oid targetTypeId, int32 targetTypMod, Oid targetCollation, List *subscripts, List *indirection, ListCell *next_indirection, Node *rhs, CoercionContext ccontext, int location)
static List * ExpandRowReference(ParseState *pstate, Node *expr, bool make_target_entry)
void updateTargetListEntry(ParseState *pstate, TargetEntry *tle, char *colname, int attrno, List *indirection, int location)
void resolveTargetListUnknowns(ParseState *pstate, List *targetlist)
TargetEntry * transformTargetEntry(ParseState *pstate, Node *node, Node *expr, ParseExprKind exprKind, char *colname, bool resjunk)
void markTargetListOrigins(ParseState *pstate, List *targetlist)
List * checkInsertTargets(ParseState *pstate, List *cols, List **attrnos)
static List * ExpandIndirectionStar(ParseState *pstate, A_Indirection *ind, bool make_target_entry, ParseExprKind exprKind)
Node * transformAssignmentIndirection(ParseState *pstate, Node *basenode, const char *targetName, bool targetIsSubscripting, Oid targetTypeId, int32 targetTypMod, Oid targetCollation, List *indirection, ListCell *indirection_cell, Node *rhs, CoercionContext ccontext, int location)
static List * ExpandAllTables(ParseState *pstate, int location)
List * transformExpressionList(ParseState *pstate, List *exprlist, ParseExprKind exprKind, bool allowDefault)
char * FigureColname(Node *node)
TupleDesc expandRecordVariable(ParseState *pstate, Var *var, int levelsup)
Oid typeidTypeRelid(Oid type_id)
#define GetCTETargetList(cte)
FormData_pg_attribute * Form_pg_attribute
static int list_length(const List *l)
#define forboth(cell1, list1, cell2, list2)
#define for_each_cell(cell, lst, initcell)
static ListCell * list_head(const List *l)
static void * list_nth(const List *list, int n)
static ListCell * lnext(const List *l, const ListCell *c)
#define list_make1_int(x1)
#define RelationGetNumberOfAttributes(relation)
#define RelationGetRelationName(relation)
RTEPermissionInfo * p_perminfo
ParseState * parentParseState
ParseNamespaceItem * p_target_nsitem
ParseExprKind p_expr_kind
List * p_multiassign_exprs
PreParseColumnRefHook p_pre_columnref_hook
Relation p_target_relation
PostParseColumnRefHook p_post_columnref_hook
TupleDesc CreateTemplateTupleDesc(int natts)
void TupleDescInitEntryCollation(TupleDesc desc, AttrNumber attributeNumber, Oid collationid)
void TupleDescInitEntry(TupleDesc desc, AttrNumber attributeNumber, const char *attributeName, Oid oidtypeid, int32 typmod, int attdim)
#define TupleDescAttr(tupdesc, i)