116#define NUM_EXEC_TLIST(parentplan) ((parentplan)->plan_rows)
117#define NUM_EXEC_QUAL(parentplan) ((parentplan)->plan_rows * 2.0)
126#define ISREGCLASSCONST(con) \
127 (((con)->consttype == REGCLASSOID || (con)->consttype == OIDOID) && \
130#define fix_scan_list(root, lst, rtoffset, num_exec) \
131 ((List *) fix_scan_expr(root, (Node *) (lst), rtoffset, num_exec))
161 int rtoffset,
double num_exec);
190 Index acceptable_rel,
208 Index resultRelation,
308 foreach(
lc,
root->rowMarks)
322 newrc->rti += rtoffset;
323 newrc->prti += rtoffset;
333 foreach(
lc,
root->append_rel_list)
338 appinfo->parent_relid += rtoffset;
339 appinfo->child_relid += rtoffset;
351 if (
root->hasAlternativeSubPlans)
353 root->isAltSubplan = (
bool *)
355 root->isUsedSubplan = (
bool *)
370 if (
root->hasAlternativeSubPlans)
412 if (
root->glob->finalrtable !=
NIL)
420 rtinfo->dummy = recursing;
433 foreach(
lc,
root->parse->rtable)
453 foreach(
lc,
root->parse->rtable)
493 else if (recursing ||
618 if (
rte->perminfoindex > 0)
632 newrte->perminfoindex = 0;
650 plan->plan_node_id =
root->glob->lastPlanNodeId++;
662 splan->
scan.plan.targetlist =
665 splan->
scan.plan.qual =
675 splan->
scan.plan.targetlist =
678 splan->
scan.plan.qual =
691 splan->
scan.plan.targetlist =
694 splan->
scan.plan.qual =
738 splan->
scan.plan.targetlist =
741 splan->
scan.plan.qual =
754 splan->
scan.plan.targetlist =
757 splan->
scan.plan.qual =
770 splan->
scan.plan.targetlist =
773 splan->
scan.plan.qual =
791 splan->
scan.plan.targetlist =
794 splan->
scan.plan.qual =
806 splan->
scan.plan.targetlist =
809 splan->
scan.plan.qual =
822 splan->
scan.plan.targetlist =
825 splan->
scan.plan.qual =
838 splan->
scan.plan.targetlist =
841 splan->
scan.plan.qual =
851 splan->
scan.plan.targetlist =
854 splan->
scan.plan.qual =
864 splan->
scan.plan.targetlist =
867 splan->
scan.plan.qual =
951 rc->
prti += rtoffset;
1013 wplan->runCondition,
1023 wplan->startOffset =
1028 wplan->runCondition,
1032 wplan->runConditionOrig,
1075 if (var &&
IsA(var,
Var))
1081 else if (var->
varno == 0)
1234 foreach(l, mergeActionList)
1249 (
List *) action->qual,
1258 mergeJoinCondition = (
Node *)
1260 (
List *) mergeJoinCondition,
1284 rc->
rti += rtoffset;
1285 rc->
prti += rtoffset;
1292 root->glob->resultRelations =
1297 root->glob->resultRelations =
1349 elog(
ERROR,
"unrecognized node type: %d",
1394 foreach(
lc,
plan->indextlist)
1404 plan->scan.scanrelid += rtoffset;
1405 plan->scan.plan.targetlist = (
List *)
1407 (
Node *)
plan->scan.plan.targetlist,
1475 scanrelid =
plan->scan.scanrelid + rtoffset;
1488 plan->scan.scanrelid += rtoffset;
1489 plan->scan.plan.targetlist =
1492 plan->scan.plan.qual =
1543 if (
plan->scan.plan.qual !=
NIL)
1556 if (
ptle->resjunk !=
ctle->resjunk)
1647 if (
fscan->scan.scanrelid > 0)
1648 fscan->scan.scanrelid += rtoffset;
1650 if (
fscan->fdw_scan_tlist !=
NIL ||
fscan->scan.scanrelid == 0)
1692 fscan->fdw_scan_tlist =
1702 fscan->scan.plan.targetlist =
1705 fscan->scan.plan.qual =
1711 fscan->fdw_recheck_quals =
1720 if (
fscan->resultRelation > 0)
1721 fscan->resultRelation += rtoffset;
1736 if (
cscan->scan.scanrelid > 0)
1737 cscan->scan.scanrelid += rtoffset;
1739 if (
cscan->custom_scan_tlist !=
NIL ||
cscan->scan.scanrelid == 0)
1770 cscan->custom_scan_tlist =
1777 cscan->scan.plan.targetlist =
1780 cscan->scan.plan.qual =
1783 cscan->custom_exprs =
1789 foreach(
lc,
cscan->custom_plans)
1818 Assert(part_prune_index >= 0 &&
1829 foreach(l2, prune_infos)
1851 prelinfo->leafpart_rti_map[
i] += rtoffset;
1852 if (
prelinfo->initial_pruning_steps)
1887 foreach(l,
aplan->appendplans)
1931 if (
aplan->part_prune_index >= 0)
1932 aplan->part_prune_index =
1964 foreach(l,
mplan->mergeplans)
2009 if (
mplan->part_prune_index >= 0)
2010 mplan->part_prune_index =
2108 ((
Aggref *) node)->aggfnoid);
2157 root->glob->relationOids =
2175 foreach(
lc, g->refs)
2202 int colno = p->
paramid & 0xFFFF;
2292 if (rtoffset != 0 ||
2293 root->multiexpr_params !=
NIL ||
2294 root->glob->lastPHId != 0 ||
2296 root->hasAlternativeSubPlans)
2338 if (var->varnosyn > 0)
2339 var->varnosyn += context->
rtoffset;
2340 return (
Node *) var;
2364 return (
Node *) cexpr;
2406 Plan *outer_plan = join->plan.lefttree;
2407 Plan *inner_plan = join->plan.righttree;
2436 foreach(
lc,
nl->nestParams)
2461 elog(
ERROR,
"NestLoopParam was not reduced to a simple Var");
2514 join->plan.targetlist,
2530 pfree(outer_itlist);
2531 pfree(inner_itlist);
2571 root->group_rtindex > 0 &&
2585 foreach(l,
plan->targetlist)
2591 if (
tle->ressortgroupref != 0)
2595 tle->ressortgroupref,
2630 pfree(subplan_itlist);
2645 if (
plan->lefttree->extParam)
2653 foreach(l,
proot->init_plans)
2770 foreach(l,
plan->targetlist)
2843 itlist->has_ph_vars =
false;
2844 itlist->has_non_vars =
false;
2859 vinfo->varnullingrels = var->varnullingrels;
2863 itlist->has_ph_vars =
true;
2865 itlist->has_non_vars =
true;
2894 itlist->has_ph_vars =
false;
2895 itlist->has_non_vars =
false;
2912 vinfo->varnullingrels = var->varnullingrels;
2917 itlist->has_ph_vars =
true;
2941 int newvarno,
int rtoffset,
2944 int varno = var->
varno;
2953 if (
vinfo->varno == varno &&
vinfo->varattno == varattno)
2972 if (!(varattno <= 0 ||
2978 elog(
ERROR,
"wrong varnullingrels %s (expected %s) for Var %d/%d",
2983 newvar->varno = newvarno;
2985 if (
newvar->varnosyn > 0)
2986 newvar->varnosyn += rtoffset;
3034 elog(
ERROR,
"wrong phnullingrels %s (expected %s) for PlaceHolderVar %d",
3117 if (
tle->ressortgroupref == sortgroupref &&
3180 Index acceptable_rel,
3217 elog(
ERROR,
"variable returning old/new found outside RETURNING list");
3219 elog(
ERROR,
"wrong varno %d (expected %d) for variable returning old/new",
3252 if (var->varnosyn > 0)
3253 var->varnosyn += context->
rtoffset;
3254 return (
Node *) var;
3258 elog(
ERROR,
"variable not found in subplan target lists");
3386 elog(
ERROR,
"variable not found in subplan target list");
3474 Index resultRelation,
3530 elog(
ERROR,
"WindowFunc not found in subplan target lists");
3595 if (
root->minmax_aggs !=
NIL &&
3601 foreach(
lc,
root->minmax_aggs)
3708 List **relationOids,
3710 bool *hasRowSecurity)
3716 MemSet(&glob, 0,
sizeof(glob));
3784 if (query->hasRowSecurity)
Bitmapset * bms_make_singleton(int x)
Bitmapset * bms_intersect(const Bitmapset *a, const Bitmapset *b)
bool bms_equal(const Bitmapset *a, const Bitmapset *b)
int bms_next_member(const Bitmapset *a, int prevbit)
bool bms_is_subset(const Bitmapset *a, const Bitmapset *b)
Bitmapset * bms_add_member(Bitmapset *a, int x)
#define Assert(condition)
#define FLEXIBLE_ARRAY_MEMBER
#define MemSet(start, val, len)
#define OidIsValid(objectId)
bool equal(const void *a, const void *b)
#define palloc_object(type)
List * lappend(List *list, void *datum)
List * list_concat(List *list1, const List *list2)
List * lappend_int(List *list, int datum)
List * lappend_oid(List *list, Oid datum)
Datum lca(PG_FUNCTION_ARGS)
Var * makeVarFromTargetEntry(int varno, TargetEntry *tle)
Var * makeVar(int varno, AttrNumber varattno, Oid vartype, int32 vartypmod, Oid varcollid, Index varlevelsup)
Const * makeNullConst(Oid consttype, int32 consttypmod, Oid constcollid)
TargetEntry * makeTargetEntry(Expr *expr, AttrNumber resno, char *resname, bool resjunk)
TargetEntry * flatCopyTargetEntry(TargetEntry *src_tle)
void pfree(void *pointer)
void * palloc0(Size size)
Oid exprType(const Node *expr)
int32 exprTypmod(const Node *expr)
Oid exprCollation(const Node *expr)
void set_sa_opfuncid(ScalarArrayOpExpr *opexpr)
void set_opfuncid(OpExpr *opexpr)
#define expression_tree_mutator(n, m, c)
#define query_tree_walker(q, w, c, f)
#define expression_tree_walker(n, w, c)
#define QTW_EXAMINE_RTES_BEFORE
#define IsA(nodeptr, _type_)
#define DO_AGGSPLIT_COMBINE(as)
@ AGGSPLIT_FINAL_DESERIAL
@ AGGSPLIT_INITIAL_SERIAL
char * bmsToString(const Bitmapset *bms)
RTEPermissionInfo * getRTEPermissionInfo(List *rteperminfos, RangeTblEntry *rte)
RTEPermissionInfo * addRTEPermissionInfo(List **rteperminfos, RangeTblEntry *rte)
#define lfirst_node(type, lc)
static int list_length(const List *l)
#define forboth(cell1, list1, cell2, list2)
#define foreach_current_index(var_or_cell)
#define forthree(cell1, list1, cell2, list2, cell3, list3)
static void * list_nth(const List *list, int n)
#define list_nth_node(type, list, n)
void mark_partial_aggref(Aggref *agg, AggSplit aggsplit)
@ SUBQUERY_SCAN_NONTRIVIAL
static Oid DatumGetObjectId(Datum X)
static Datum ObjectIdGetDatum(Oid X)
#define IS_SPECIAL_VARNO(varno)
RelOptInfo * find_base_rel(PlannerInfo *root, int relid)
RelOptInfo * fetch_upper_rel(PlannerInfo *root, UpperRelationKind kind, Relids relids)
Node * remove_nulling_relids(Node *node, const Bitmapset *removable_relids, const Bitmapset *except_relids)
void record_plan_type_dependency(PlannerInfo *root, Oid typid)
#define NUM_EXEC_QUAL(parentplan)
static void set_hash_references(PlannerInfo *root, Plan *plan, int rtoffset)
static void fix_expr_common(PlannerInfo *root, Node *node)
static void record_elided_node(PlannerGlobal *glob, int plan_node_id, NodeTag elided_type, Bitmapset *relids)
static void add_rtes_to_flat_rtable(PlannerInfo *root, bool recursing)
static Node * fix_join_expr_mutator(Node *node, fix_join_expr_context *context)
static void add_rte_to_flat_rtable(PlannerGlobal *glob, List *rteperminfos, RangeTblEntry *rte)
static Plan * set_append_references(PlannerInfo *root, Append *aplan, int rtoffset)
Plan * set_plan_references(PlannerInfo *root, Plan *plan)
static Plan * set_mergeappend_references(PlannerInfo *root, MergeAppend *mplan, int rtoffset)
static List * set_returning_clause_references(PlannerInfo *root, List *rlist, Plan *topplan, Index resultRelation, int rtoffset)
static Node * fix_param_node(PlannerInfo *root, Param *p)
void record_plan_function_dependency(PlannerInfo *root, Oid funcid)
static Relids offset_relid_set(Relids relids, int rtoffset)
static bool flatten_rtes_walker(Node *node, flatten_rtes_walker_context *cxt)
static indexed_tlist * build_tlist_index(List *tlist)
static List * set_windowagg_runcondition_references(PlannerInfo *root, List *runcondition, Plan *plan)
bool trivial_subqueryscan(SubqueryScan *plan)
static void set_upper_references(PlannerInfo *root, Plan *plan, int rtoffset)
static Var * search_indexed_tlist_for_sortgroupref(Expr *node, Index sortgroupref, indexed_tlist *itlist, int newvarno)
static void flatten_unplanned_rtes(PlannerGlobal *glob, RangeTblEntry *rte)
static Node * fix_upper_expr(PlannerInfo *root, Node *node, indexed_tlist *subplan_itlist, int newvarno, int rtoffset, NullingRelsMatch nrm_match, double num_exec)
static void set_param_references(PlannerInfo *root, Plan *plan)
static Var * search_indexed_tlist_for_non_var(Expr *node, indexed_tlist *itlist, int newvarno)
static Node * fix_upper_expr_mutator(Node *node, fix_upper_expr_context *context)
Param * find_minmax_agg_replacement_param(PlannerInfo *root, Aggref *aggref)
static Node * fix_scan_expr_mutator(Node *node, fix_scan_expr_context *context)
static void set_foreignscan_references(PlannerInfo *root, ForeignScan *fscan, int rtoffset)
static Plan * set_subqueryscan_references(PlannerInfo *root, SubqueryScan *plan, int rtoffset)
static Var * search_indexed_tlist_for_phv(PlaceHolderVar *phv, indexed_tlist *itlist, int newvarno, NullingRelsMatch nrm_match)
static Plan * set_indexonlyscan_references(PlannerInfo *root, IndexOnlyScan *plan, int rtoffset)
static List * fix_join_expr(PlannerInfo *root, List *clauses, indexed_tlist *outer_itlist, indexed_tlist *inner_itlist, Index acceptable_rel, int rtoffset, NullingRelsMatch nrm_match, double num_exec)
static Node * convert_combining_aggrefs(Node *node, void *context)
static void set_dummy_tlist_references(Plan *plan, int rtoffset)
static int register_partpruneinfo(PlannerInfo *root, int part_prune_index, int rtoffset)
static void set_customscan_references(PlannerInfo *root, CustomScan *cscan, int rtoffset)
#define ISREGCLASSCONST(con)
void extract_query_dependencies(Node *query, List **relationOids, List **invalItems, bool *hasRowSecurity)
static Node * fix_windowagg_condition_expr_mutator(Node *node, fix_windowagg_cond_context *context)
static Var * copyVar(Var *var)
bool extract_query_dependencies_walker(Node *node, PlannerInfo *context)
static List * fix_windowagg_condition_expr(PlannerInfo *root, List *runcondition, indexed_tlist *subplan_itlist)
#define NUM_EXEC_TLIST(parentplan)
static Node * fix_alternative_subplan(PlannerInfo *root, AlternativeSubPlan *asplan, double num_exec)
static void set_join_references(PlannerInfo *root, Join *join, int rtoffset)
static indexed_tlist * build_tlist_index_other_vars(List *tlist, int ignore_rel)
static Plan * clean_up_removed_plan_level(Plan *parent, Plan *child)
static Node * fix_scan_expr(PlannerInfo *root, Node *node, int rtoffset, double num_exec)
static Plan * set_plan_refs(PlannerInfo *root, Plan *plan, int rtoffset)
static bool fix_scan_expr_walker(Node *node, fix_scan_expr_context *context)
static Var * search_indexed_tlist_for_var(Var *var, indexed_tlist *itlist, int newvarno, int rtoffset, NullingRelsMatch nrm_match)
#define fix_scan_list(root, lst, rtoffset, num_exec)
List * mergeJoinConditions
List * withCheckOptionLists
OnConflictAction onConflictAction
Bitmapset * prunableRelids
struct TableSampleClause * tablesample
VarReturningType varreturningtype
NullingRelsMatch nrm_match
indexed_tlist * outer_itlist
indexed_tlist * inner_itlist
indexed_tlist * subplan_itlist
NullingRelsMatch nrm_match
indexed_tlist * subplan_itlist
Bitmapset * varnullingrels
void SS_compute_initplan_cost(List *init_plans, Cost *initplan_cost_p, bool *unsafe_initplans_p)
#define GetSysCacheHashValue1(cacheId, key1)
TargetEntry * tlist_member(Expr *node, List *targetlist)
void apply_tlist_labeling(List *dest_tlist, List *src_tlist)
#define FirstUnpinnedObjectId
Query * UtilityContainsQuery(Node *parsetree)