109#define REL_ALIAS_PREFIX "r"
111#define ADD_REL_QUALIFIER(buf, varno) \
112 appendStringInfo((buf), "%s%d.", REL_ALIAS_PREFIX, (varno))
113#define SUBQUERY_REL_ALIAS_PREFIX "s"
114#define SUBQUERY_COL_ALIAS_PREFIX "c"
136 List **retrieved_attrs);
139 List **retrieved_attrs,
145 List *withCheckOptionList,
147 List **retrieved_attrs);
183 List **additional_conds,
191 List **additional_conds,
List **params_list);
206 int *relno,
int *colno);
208 int *relno,
int *colno);
229 foreach(lc, input_conds)
234 *remote_conds =
lappend(*remote_conds, ri);
236 *local_conds =
lappend(*local_conds, ri);
317 bool check_type =
true;
363 collation = var->varcollid;
369 collation = var->varcollid;
371 collation == DEFAULT_COLLATION_OID)
401 switch (
c->consttype)
404 case REGPROCEDUREOID:
406 ProcedureRelationId, fpinfo))
412 OperatorRelationId, fpinfo))
417 RelationRelationId, fpinfo))
422 TypeRelationId, fpinfo))
425 case REGCOLLATIONOID:
427 CollationRelationId, fpinfo))
441 TSConfigRelationId, fpinfo))
444 case REGDICTIONARYOID:
447 TSDictionaryRelationId, fpinfo))
450 case REGNAMESPACEOID:
452 NamespaceRelationId, fpinfo))
457 AuthIdRelationId, fpinfo))
462 DatabaseRelationId, fpinfo))
474 collation =
c->constcollid;
476 collation == DEFAULT_COLLATION_OID)
507 collation == DEFAULT_COLLATION_OID)
513 case T_SubscriptingRef:
527 glob_cxt, &inner_cxt, case_arg_cxt))
532 glob_cxt, &inner_cxt, case_arg_cxt))
537 glob_cxt, &inner_cxt, case_arg_cxt))
545 collation = sr->refcollid;
549 collation == inner_cxt.collation)
551 else if (collation == DEFAULT_COLLATION_OID)
573 glob_cxt, &inner_cxt, case_arg_cxt))
583 fe->inputcollid != inner_cxt.collation)
592 collation =
fe->funccollid;
596 collation == inner_cxt.collation)
598 else if (collation == DEFAULT_COLLATION_OID)
621 glob_cxt, &inner_cxt, case_arg_cxt))
631 oe->inputcollid != inner_cxt.collation)
635 collation = oe->opcollid;
639 collation == inner_cxt.collation)
641 else if (collation == DEFAULT_COLLATION_OID)
647 case T_ScalarArrayOpExpr:
661 glob_cxt, &inner_cxt, case_arg_cxt))
671 oe->inputcollid != inner_cxt.collation)
687 glob_cxt, &inner_cxt, case_arg_cxt))
694 collation = r->resultcollid;
698 collation == inner_cxt.collation)
700 else if (collation == DEFAULT_COLLATION_OID)
706 case T_ArrayCoerceExpr:
714 glob_cxt, &inner_cxt, case_arg_cxt))
722 collation =
e->resultcollid;
726 collation == inner_cxt.collation)
728 else if (collation == DEFAULT_COLLATION_OID)
742 glob_cxt, &inner_cxt, case_arg_cxt))
758 glob_cxt, &inner_cxt, case_arg_cxt))
783 glob_cxt, &arg_cxt, case_arg_cxt))
788 foreach(lc, ce->
args)
811 opArgs = ((
OpExpr *) whenExpr)->args;
826 glob_cxt, &tmp_cxt, &arg_cxt))
831 glob_cxt, &inner_cxt, case_arg_cxt))
837 glob_cxt, &inner_cxt, case_arg_cxt))
848 collation = ce->casecollid;
854 else if (collation == DEFAULT_COLLATION_OID)
873 collation =
c->collation;
879 else if (collation == DEFAULT_COLLATION_OID)
893 glob_cxt, &inner_cxt, case_arg_cxt))
900 collation =
a->array_collid;
904 collation == inner_cxt.collation)
906 else if (collation == DEFAULT_COLLATION_OID)
923 glob_cxt, &inner_cxt, case_arg_cxt))
960 foreach(lc, agg->
args)
973 glob_cxt, &inner_cxt, case_arg_cxt))
1006 glob_cxt, &inner_cxt, case_arg_cxt))
1016 agg->inputcollid != inner_cxt.
collation)
1025 collation = agg->aggcollid;
1031 else if (collation == DEFAULT_COLLATION_OID)
1076 if (outer_cxt->
collation == DEFAULT_COLLATION_OID)
1081 else if (collation != DEFAULT_COLLATION_OID)
1134 relids = baserel->
relids;
1268 bool has_final_sort,
bool has_limit,
bool is_subquery,
1269 List **retrieved_attrs,
List **params_list)
1304 quals = remote_conds;
1420 (
Index) 0, NULL, &additional_conds,
1423 if (additional_conds !=
NIL)
1445 List **retrieved_attrs)
1452 *retrieved_attrs =
NIL;
1459 for (
i = 1;
i <= tupdesc->
natts;
i++)
1464 if (attr->attisdropped)
1467 if (have_wholerow ||
1473 else if (is_returning)
1492 else if (is_returning)
1505 if (first && !is_returning)
1608 bool is_first =
true;
1644 bool need_and =
false;
1647 if (exprs !=
NIL || additional_conds !=
NIL)
1663 foreach(lc, additional_conds)
1695 elog(
ERROR,
"unsupported join type %d", jointype);
1716 List **retrieved_attrs,
1723 *retrieved_attrs =
NIL;
1731 else if (is_returning)
1736 *retrieved_attrs =
lappend_int(*retrieved_attrs,
i + 1);
1740 if (
i == 0 && !is_returning)
1795 bool use_alias,
Index ignore_rel,
List **ignore_conds,
1796 List **additional_conds,
List **params_list)
1806 bool outerrel_is_target =
false;
1807 bool innerrel_is_target =
false;
1808 List *additional_conds_i =
NIL;
1809 List *additional_conds_o =
NIL;
1834 if (outerrel->
relid == ignore_rel)
1835 outerrel_is_target =
true;
1836 else if (innerrel->
relid == ignore_rel)
1837 innerrel_is_target =
true;
1841 if (!outerrel_is_target)
1846 ignore_rel, ignore_conds, &additional_conds_o,
1858 if (innerrel_is_target)
1864 if (additional_conds_o !=
NIL)
1867 *additional_conds = additional_conds_o;
1874 if (!innerrel_is_target)
1879 ignore_rel, ignore_conds, &additional_conds_i,
1916 if (additional_conds_i !=
NIL)
1919 additional_conds_i =
NIL;
1925 *additional_conds =
lappend(*additional_conds,
str.data);
1932 if (outerrel_is_target)
1938 if (additional_conds_i !=
NIL)
1941 *additional_conds = additional_conds_i;
1948 Assert(!outerrel_is_target && !innerrel_is_target);
1997 if (additional_conds_o !=
NIL)
1999 *additional_conds =
list_concat(*additional_conds,
2000 additional_conds_o);
2004 if (additional_conds_i !=
NIL)
2006 *additional_conds =
list_concat(*additional_conds,
2007 additional_conds_i);
2042 bool make_subquery,
Index ignore_rel,
List **ignore_conds,
2043 List **additional_conds,
List **params_list)
2055 List *retrieved_attrs;
2063 Assert(ignore_rel == 0 ||
2071 &retrieved_attrs, params_list);
2089 for (
i = 1;
i <= ncols;
i++)
2101 ignore_conds, additional_conds,
2118 List *targetAttrs,
bool doNothing,
2119 List *withCheckOptionList,
List *returningList,
2120 List **retrieved_attrs,
int *values_end_len)
2135 foreach(lc, targetAttrs)
2150 foreach(lc, targetAttrs)
2159 if (attr->attgenerated)
2172 *values_end_len =
buf->len;
2179 withCheckOptionList, returningList, retrieved_attrs);
2190 char *orig_query,
List *target_attrs,
2191 int values_end_len,
int num_params,
2201 Assert((values_end_len > 0) && (values_end_len <= strlen(orig_query)));
2210 pindex = num_params + 1;
2211 for (
i = 0;
i < num_rows;
i++)
2216 foreach(lc, target_attrs)
2225 if (attr->attgenerated)
2252 List *withCheckOptionList,
List *returningList,
2253 List **retrieved_attrs)
2266 foreach(lc, targetAttrs)
2276 if (attr->attgenerated)
2288 withCheckOptionList, returningList, retrieved_attrs);
2316 List *returningList,
2317 List **retrieved_attrs)
2344 forboth(lc, targetlist, lc2, targetAttrs)
2370 &ignore_conds, &additional_conds, params_list);
2371 remote_conds =
list_concat(remote_conds, ignore_conds);
2376 if (additional_conds !=
NIL)
2384 NIL, returningList, retrieved_attrs);
2397 List *returningList,
2398 List **retrieved_attrs)
2406 NIL, returningList, retrieved_attrs);
2429 List *returningList,
2430 List **retrieved_attrs)
2453 &ignore_conds, &additional_conds, params_list);
2454 remote_conds =
list_concat(remote_conds, ignore_conds);
2459 if (additional_conds !=
NIL)
2467 rtindex, rel,
false,
2468 NIL, returningList, retrieved_attrs);
2477 bool trig_after_row,
2478 List *withCheckOptionList,
2479 List *returningList,
2480 List **retrieved_attrs)
2491 if (withCheckOptionList !=
NIL)
2506 if (returningList !=
NIL)
2516 if (attrs_used != NULL)
2520 *retrieved_attrs =
NIL;
2596 List **retrieved_attrs)
2606 *retrieved_attrs =
NIL;
2609 for (
i = 0;
i < tupdesc->
natts;
i++)
2627 if (strcmp(def->
defname,
"column_name") == 0)
2636 *retrieved_attrs =
lappend_int(*retrieved_attrs,
i + 1);
2650 switch (sample_method)
2670 elog(
ERROR,
"unexpected sampling method");
2699 restart_seqs ?
"RESTART" :
"CONTINUE");
2724 else if (varattno < 0)
2735 fetchval = rte->relid;
2746 else if (varattno == 0)
2753 List *retrieved_attrs;
2799 char *colname = NULL;
2815 if (strcmp(def->
defname,
"column_name") == 0)
2826 if (colname == NULL)
2827 colname =
get_attname(rte->relid, varattno,
false);
2845 const char *nspname = NULL;
2855 foreach(lc,
table->options)
2859 if (strcmp(def->
defname,
"schema_name") == 0)
2861 else if (strcmp(def->
defname,
"table_name") == 0)
2869 if (nspname == NULL)
2892 if (strchr(
val,
'\\') != NULL)
2895 for (valptr =
val; *valptr; valptr++)
2933 case T_SubscriptingRef:
2942 case T_DistinctExpr:
2945 case T_ScalarArrayOpExpr:
2951 case T_ArrayCoerceExpr:
2970 elog(
ERROR,
"unsupported expression type for deparse: %d",
3062 bool isfloat =
false;
3063 bool isstring =
false;
3066 if (node->constisnull)
3072 node->consttypmod));
3077 &typoutput, &typIsVarlena);
3094 if (strspn(extval,
"0123456789+-eE.") == strlen(extval))
3096 if (extval[0] ==
'+' || extval[0] ==
'-')
3100 if (strcspn(extval,
"eE.") != strlen(extval))
3112 if (strcmp(extval,
"t") == 0)
3143 needlabel = !isfloat || (node->consttypmod >= 0);
3149 needlabel = !isstring;
3155 if (needlabel || showtype > 0)
3158 node->consttypmod));
3272 Oid rettype = node->funcresulttype;
3273 int32 coercedTypmod;
3285 use_variadic = node->funcvariadic;
3318 bool canSuppressRightConstCast =
false;
3324 elog(
ERROR,
"cache lookup failed for operator %u", node->
opno);
3326 oprkind = form->oprkind;
3343 bool canSuppressLeftConstCast =
false;
3371 if (leftType == rightType)
3379 if (canSuppressLeftConstCast)
3393 if (canSuppressRightConstCast)
3447 opname =
NameStr(opform->oprname);
3450 if (opform->oprnamespace != PG_CATALOG_NAMESPACE)
3452 const char *opnspname;
3499 elog(
ERROR,
"cache lookup failed for operator %u", node->
opno);
3539 node->resulttypmod));
3557 node->resulttypmod));
3567 const char *op = NULL;
3588 foreach(lc, node->
args)
3643 if (node->
arg != NULL)
3650 foreach(lc, node->
args)
3656 if (node->
arg == NULL)
3692 foreach(lc, node->elements)
3702 if (node->elements ==
NIL)
3720 use_variadic = node->aggvariadic;
3729 if (AGGKIND_IS_ORDERED_SET(node->aggkind))
3735 Assert(!node->aggvariadic);
3809 foreach(lc, orderList)
3842 if (sortop == typentry->
lt_opr)
3844 else if (sortop == typentry->
gt_opr)
3856 elog(
ERROR,
"cache lookup failed for operator %u", sortop);
3970 bool gotone =
false;
3975 foreach(lcell, pathkeys)
4003 elog(
ERROR,
"could not find pathkey item to sort");
4037 elog(
ERROR,
"missing operator %d(%u,%u) in opfamily %u",
4067 if (
root->parse->limitCount)
4072 if (
root->parse->limitOffset)
4095 elog(
ERROR,
"cache lookup failed for function %u", funcid);
4099 if (procform->pronamespace != PG_CATALOG_NAMESPACE)
4101 const char *schemaname;
4146 else if (!expr ||
IsA(expr,
Var))
4156 return (
Node *) expr;
4229 int *relno,
int *colno)
4261 elog(
ERROR,
"unexpected expression in subquery output");
Bitmapset * bms_make_singleton(int x)
int bms_next_member(const Bitmapset *a, int prevbit)
void bms_free(Bitmapset *a)
bool bms_is_member(int x, const Bitmapset *a)
Bitmapset * bms_add_member(Bitmapset *a, int x)
BMS_Membership bms_membership(const Bitmapset *a)
#define FORMAT_TYPE_TYPEMOD_GIVEN
#define FORMAT_TYPE_FORCE_QUALIFY
#define ESCAPE_STRING_SYNTAX
#define SQL_STR_DOUBLE(ch, escape_backslash)
#define OidIsValid(objectId)
bool contain_mutable_functions(Node *clause)
char * defGetString(DefElem *def)
static void deparseArrayCoerceExpr(ArrayCoerceExpr *node, deparse_expr_cxt *context)
static void deparseRangeTblRef(StringInfo buf, PlannerInfo *root, RelOptInfo *foreignrel, bool make_subquery, Index ignore_rel, List **ignore_conds, List **additional_conds, List **params_list)
static void deparseCaseExpr(CaseExpr *node, deparse_expr_cxt *context)
void deparseAnalyzeSizeSql(StringInfo buf, Relation rel)
static void deparseBoolExpr(BoolExpr *node, deparse_expr_cxt *context)
static void appendGroupByClause(List *tlist, deparse_expr_cxt *context)
static void deparseTargetList(StringInfo buf, RangeTblEntry *rte, Index rtindex, Relation rel, bool is_returning, Bitmapset *attrs_used, bool qualify_col, List **retrieved_attrs)
#define SUBQUERY_REL_ALIAS_PREFIX
static void deparseFromExpr(List *quals, deparse_expr_cxt *context)
static Node * deparseSortGroupClause(Index ref, List *tlist, bool force_colno, deparse_expr_cxt *context)
static void deparseLockingClause(deparse_expr_cxt *context)
const char * get_jointype_name(JoinType jointype)
void deparseAnalyzeInfoSql(StringInfo buf, Relation rel)
static void deparseAggref(Aggref *node, deparse_expr_cxt *context)
static void appendOrderBySuffix(Oid sortop, Oid sortcoltype, bool nulls_first, deparse_expr_cxt *context)
void deparseDirectDeleteSql(StringInfo buf, PlannerInfo *root, Index rtindex, Relation rel, RelOptInfo *foreignrel, List *remote_conds, List **params_list, List *returningList, List **retrieved_attrs)
void deparseDirectUpdateSql(StringInfo buf, PlannerInfo *root, Index rtindex, Relation rel, RelOptInfo *foreignrel, List *targetlist, List *targetAttrs, List *remote_conds, List **params_list, List *returningList, List **retrieved_attrs)
struct deparse_expr_cxt deparse_expr_cxt
static void get_relation_column_alias_ids(Var *node, RelOptInfo *foreignrel, int *relno, int *colno)
static void printRemoteParam(int paramindex, Oid paramtype, int32 paramtypmod, deparse_expr_cxt *context)
static bool is_subquery_var(Var *node, RelOptInfo *foreignrel, int *relno, int *colno)
bool is_foreign_param(PlannerInfo *root, RelOptInfo *baserel, Expr *expr)
static void printRemotePlaceholder(Oid paramtype, int32 paramtypmod, deparse_expr_cxt *context)
static void appendOrderByClause(List *pathkeys, bool has_final_sort, deparse_expr_cxt *context)
static bool foreign_expr_walker(Node *node, foreign_glob_cxt *glob_cxt, foreign_loc_cxt *outer_cxt, foreign_loc_cxt *case_arg_cxt)
static void deparseColumnRef(StringInfo buf, int varno, int varattno, RangeTblEntry *rte, bool qualify_col)
static void deparseRelabelType(RelabelType *node, deparse_expr_cxt *context)
static void deparseNullTest(NullTest *node, deparse_expr_cxt *context)
static void deparseOperatorName(StringInfo buf, Form_pg_operator opform)
static void deparseOpExpr(OpExpr *node, deparse_expr_cxt *context)
static void deparseConst(Const *node, deparse_expr_cxt *context, int showtype)
static bool isPlainForeignVar(Expr *node, deparse_expr_cxt *context)
static void deparseDistinctExpr(DistinctExpr *node, deparse_expr_cxt *context)
void deparseSelectStmtForRel(StringInfo buf, PlannerInfo *root, RelOptInfo *rel, List *tlist, List *remote_conds, List *pathkeys, bool has_final_sort, bool has_limit, bool is_subquery, List **retrieved_attrs, List **params_list)
static void deparseFuncExpr(FuncExpr *node, deparse_expr_cxt *context)
void deparseStringLiteral(StringInfo buf, const char *val)
void rebuildInsertSql(StringInfo buf, Relation rel, char *orig_query, List *target_attrs, int values_end_len, int num_params, int num_rows)
struct foreign_glob_cxt foreign_glob_cxt
static void deparseArrayExpr(ArrayExpr *node, deparse_expr_cxt *context)
void deparseInsertSql(StringInfo buf, RangeTblEntry *rte, Index rtindex, Relation rel, List *targetAttrs, bool doNothing, List *withCheckOptionList, List *returningList, List **retrieved_attrs, int *values_end_len)
static void deparseReturningList(StringInfo buf, RangeTblEntry *rte, Index rtindex, Relation rel, bool trig_after_row, List *withCheckOptionList, List *returningList, List **retrieved_attrs)
void deparseUpdateSql(StringInfo buf, RangeTblEntry *rte, Index rtindex, Relation rel, List *targetAttrs, List *withCheckOptionList, List *returningList, List **retrieved_attrs)
static void deparseVar(Var *node, deparse_expr_cxt *context)
static void appendFunctionName(Oid funcid, deparse_expr_cxt *context)
static void appendConditions(List *exprs, deparse_expr_cxt *context)
struct foreign_loc_cxt foreign_loc_cxt
void deparseDeleteSql(StringInfo buf, RangeTblEntry *rte, Index rtindex, Relation rel, List *returningList, List **retrieved_attrs)
void deparseAnalyzeSql(StringInfo buf, Relation rel, PgFdwSamplingMethod sample_method, double sample_frac, List **retrieved_attrs)
static void deparseSubscriptingRef(SubscriptingRef *node, deparse_expr_cxt *context)
static void deparseRelation(StringInfo buf, Relation rel)
static void deparseExplicitTargetList(List *tlist, bool is_returning, List **retrieved_attrs, deparse_expr_cxt *context)
static char * deparse_type_name(Oid type_oid, int32 typemod)
#define ADD_REL_QUALIFIER(buf, varno)
static void appendLimitClause(deparse_expr_cxt *context)
static void deparseExpr(Expr *node, deparse_expr_cxt *context)
bool is_foreign_expr(PlannerInfo *root, RelOptInfo *baserel, Expr *expr)
static void deparseFromExprForRel(StringInfo buf, PlannerInfo *root, RelOptInfo *foreignrel, bool use_alias, Index ignore_rel, List **ignore_conds, List **additional_conds, List **params_list)
#define SUBQUERY_COL_ALIAS_PREFIX
void classifyConditions(PlannerInfo *root, RelOptInfo *baserel, List *input_conds, List **remote_conds, List **local_conds)
static void deparseScalarArrayOpExpr(ScalarArrayOpExpr *node, deparse_expr_cxt *context)
static void appendWhereClause(List *exprs, List *additional_conds, deparse_expr_cxt *context)
void deparseTruncateSql(StringInfo buf, List *rels, DropBehavior behavior, bool restart_seqs)
static void deparseSubqueryTargetList(deparse_expr_cxt *context)
bool is_foreign_pathkey(PlannerInfo *root, RelOptInfo *baserel, PathKey *pathkey)
static void deparseSelectSql(List *tlist, bool is_subquery, List **retrieved_attrs, deparse_expr_cxt *context)
static void deparseParam(Param *node, deparse_expr_cxt *context)
List * build_tlist_to_deparse(RelOptInfo *foreignrel)
static void appendAggOrderBy(List *orderList, List *targetList, deparse_expr_cxt *context)
bool equal(const void *a, const void *b)
char * OidOutputFunctionCall(Oid functionId, Datum val)
ForeignTable * GetForeignTable(Oid relid)
List * GetForeignColumnOptions(Oid relid, AttrNumber attnum)
Assert(PointerIsAligned(start, uint64))
#define HeapTupleIsValid(tuple)
static void * GETSTRUCT(const HeapTupleData *tuple)
if(TABLE==NULL||TABLE_index==NULL)
List * lappend(List *list, void *datum)
List * list_concat(List *list1, const List *list2)
List * lappend_int(List *list, int datum)
void list_free(List *list)
void list_free_deep(List *list)
bool type_is_rowtype(Oid typid)
Oid get_opfamily_member_for_cmptype(Oid opfamily, Oid lefttype, Oid righttype, CompareType cmptype)
void getTypeOutputInfo(Oid type, Oid *typOutput, bool *typIsVarlena)
char * get_attname(Oid relid, AttrNumber attnum, bool missing_ok)
char * get_namespace_name(Oid nspid)
void pfree(void *pointer)
Oid exprType(const Node *expr)
bool exprIsLengthCoercion(const Node *expr, int32 *coercedTypmod)
Node * strip_implicit_coercions(Node *node)
#define IsA(nodeptr, _type_)
#define castNode(_type_, nodeptr)
#define PVC_RECURSE_PLACEHOLDERS
#define IS_SIMPLE_REL(rel)
#define planner_rt_fetch(rti, root)
#define IS_UPPER_REL(rel)
FormData_pg_attribute * Form_pg_attribute
#define lfirst_node(type, lc)
static int list_length(const List *l)
#define forboth(cell1, list1, cell2, list2)
static ListCell * list_head(const List *l)
static ListCell * lnext(const List *l, const ListCell *c)
static const struct lconv_member_info table[]
FormData_pg_operator * Form_pg_operator
FormData_pg_proc * Form_pg_proc
static Oid DatumGetObjectId(Datum X)
static Datum ObjectIdGetDatum(Oid X)
void reset_transmission_modes(int nestlevel)
int set_transmission_modes(void)
EquivalenceMember * find_em_for_rel_target(PlannerInfo *root, EquivalenceClass *ec, RelOptInfo *rel)
EquivalenceMember * find_em_for_rel(PlannerInfo *root, EquivalenceClass *ec, RelOptInfo *rel)
bool is_shippable(Oid objectId, Oid classId, PgFdwRelationInfo *fpinfo)
bool is_builtin(Oid objectId)
@ ANALYZE_SAMPLE_BERNOULLI
PlanRowMark * get_plan_rowmark(List *rowmarks, Index rtindex)
#define IS_SPECIAL_VARNO(varno)
#define RelationGetRelid(relation)
#define RelationGetDescr(relation)
#define RelationGetRelationName(relation)
#define RelationGetNamespace(relation)
const char * quote_identifier(const char *ident)
void appendStringInfo(StringInfo str, const char *fmt,...)
void appendBinaryStringInfo(StringInfo str, const void *data, int datalen)
void appendStringInfoString(StringInfo str, const char *s)
void appendStringInfoChar(StringInfo str, char ch)
void initStringInfo(StringInfo str)
NullTestType nulltesttype
bool make_outerrel_subquery
Relids lower_subquery_rels
bool make_innerrel_subquery
LockClauseStrength strength
struct PathTarget * reltarget
bool trig_update_after_row
bool trig_insert_after_row
bool trig_delete_after_row
#define FirstLowInvalidHeapAttributeNumber
#define TableOidAttributeNumber
#define SelfItemPointerAttributeNumber
void ReleaseSysCache(HeapTuple tuple)
HeapTuple SearchSysCache1(int cacheId, Datum key1)
void table_close(Relation relation, LOCKMODE lockmode)
Relation table_open(Oid relationId, LOCKMODE lockmode)
TargetEntry * get_sortgroupref_tle(Index sortref, List *targetList)
List * add_to_flat_tlist(List *tlist, List *exprs)
#define FirstNormalObjectId
static FormData_pg_attribute * TupleDescAttr(TupleDesc tupdesc, int i)
TypeCacheEntry * lookup_type_cache(Oid type_id, int flags)
List * pull_var_clause(Node *node, int flags)
void pull_varattnos(Node *node, Index varno, Bitmapset **varattnos)