50 Index *childRTindex_p);
52 List *translated_vars);
93 bool old_isParent =
false;
94 int old_allMarkTypes = 0;
106 parentOID = rte->relid;
122 lockmode = rte->rellockmode;
139 if (oldrelation->
rd_rel->relkind == RELKIND_PARTITIONED_TABLE)
148 Assert(rte->relkind == RELKIND_PARTITIONED_TABLE);
198 if (childOID != parentOID)
201 newrelation = oldrelation;
218 &childrte, &childRTindex);
224 if (childOID != parentOID)
265 newvars =
lappend(newvars, var);
282 newvars =
lappend(newvars, var);
300 newvars =
lappend(newvars, var);
339 if (partdesc->
nparts == 0)
352 if (num_live_parts > 0)
360 Assert(relinfo->part_rels == NULL);
384 if (childrel == NULL)
396 elog(
ERROR,
"temporary relation from another session found as partition");
400 parentrel, top_parentrc, childrel,
401 &childrte, &childRTindex);
405 relinfo->part_rels[
i] = childrelinfo;
410 if (childrel->
rd_rel->relkind == RELKIND_PARTITIONED_TABLE)
419 childrte, childRTindex,
422 top_parentrc, lockmode);
455 Index *childRTindex_p)
464 List *parent_colnames;
465 List *child_colnames;
483 childrte->relid = childOID;
484 childrte->relkind = childrel->
rd_rel->relkind;
486 if (childrte->relkind == RELKIND_PARTITIONED_TABLE)
488 Assert(childOID != parentOID);
489 childrte->
inh =
true;
492 childrte->
inh =
false;
493 childrte->securityQuals =
NIL;
496 childrte->perminfoindex = 0;
501 *childrte_p = childrte;
502 *childRTindex_p = childRTindex;
508 if (childOID != parentOID)
515 parentRTindex, childRTindex);
530 parent_colnames = parentrte->eref->colnames;
531 child_colnames =
NIL;
532 for (
int cattno = 0; cattno < child_tupdesc->
natts; cattno++)
537 if (att->attisdropped)
542 else if (appinfo->parent_colnos[cattno] > 0 &&
543 appinfo->parent_colnos[cattno] <=
list_length(parent_colnames))
547 appinfo->parent_colnos[cattno] - 1));
562 childrte->alias = childrte->eref =
makeAlias(parentrte->eref->aliasname,
569 Assert(childRTindex < root->simple_rel_array_size);
570 Assert(
root->simple_rte_array[childRTindex] == NULL);
571 root->simple_rte_array[childRTindex] = childrte;
572 Assert(
root->append_rel_array[childRTindex] == NULL);
573 root->append_rel_array[childRTindex] = appinfo;
582 childrc->
rti = childRTindex;
583 childrc->
prti = top_parentrc->
rti;
597 childrc->
isParent = (childrte->relkind == RELKIND_PARTITIONED_TABLE);
618 if (childrte->relkind != RELKIND_PARTITIONED_TABLE)
668 relid =
root->parse->resultRelation;
674 if (rel->
relid != relid)
691 return bms_union(updatedCols, extraUpdatedCols);
707 List *translated_vars)
729 foreach(lc, translated_vars)
763 if (parent_cols == NULL)
767 if (rel->parent != parent_rel)
779 appinfo =
root->append_rel_array[rel->
relid];
800 foreach(l,
root->append_rel_list)
812 Assert(childRTindex < root->simple_rel_array_size);
813 childrte =
root->simple_rte_array[childRTindex];
843 Index cq_min_security;
855 cq_min_security = UINT_MAX;
868 if (childqual &&
IsA(childqual,
Const))
870 if (((
Const *) childqual)->constisnull ||
893 root->hasPseudoConstantQuals =
true;
912 childquals =
lappend(childquals, childrinfo);
929 if (childRTE->securityQuals)
931 Index security_level = 0;
933 foreach(lc, childRTE->securityQuals)
938 foreach(lc2, qualset)
943 childquals =
lappend(childquals,
950 cq_min_security =
Min(cq_min_security, security_level);
954 Assert(security_level <= root->qual_security_level);
Node * adjust_appendrel_attrs(PlannerInfo *root, Node *node, int nappinfos, AppendRelInfo **appinfos)
void add_row_identity_columns(PlannerInfo *root, Index rtindex, RangeTblEntry *target_rte, Relation target_relation)
AppendRelInfo * make_append_rel_info(Relation parentrel, Relation childrel, Index parentRTindex, Index childRTindex)
void add_row_identity_var(PlannerInfo *root, Var *orig_var, Index rtindex, const char *rowid_name)
#define InvalidAttrNumber
Bitmapset * bms_make_singleton(int x)
int bms_next_member(const Bitmapset *a, int prevbit)
Bitmapset * bms_del_member(Bitmapset *a, int x)
int bms_num_members(const Bitmapset *a)
bool bms_is_member(int x, const Bitmapset *a)
Bitmapset * bms_add_member(Bitmapset *a, int x)
Bitmapset * bms_add_members(Bitmapset *a, const Bitmapset *b)
Bitmapset * bms_union(const Bitmapset *a, const Bitmapset *b)
Node * eval_const_expressions(PlannerInfo *root, Node *node)
bool contain_volatile_functions(Node *clause)
Assert(PointerIsAligned(start, uint64))
static Bitmapset * translate_col_privs(const Bitmapset *parent_privs, List *translated_vars)
static void expand_partitioned_rtentry(PlannerInfo *root, RelOptInfo *relinfo, RangeTblEntry *parentrte, Index parentRTindex, Relation parentrel, Bitmapset *parent_updatedCols, PlanRowMark *top_parentrc, LOCKMODE lockmode)
bool apply_child_basequals(PlannerInfo *root, RelOptInfo *parentrel, RelOptInfo *childrel, RangeTblEntry *childRTE, AppendRelInfo *appinfo)
static void expand_appendrel_subquery(PlannerInfo *root, RelOptInfo *rel, RangeTblEntry *rte, Index rti)
static Bitmapset * translate_col_privs_multilevel(PlannerInfo *root, RelOptInfo *rel, RelOptInfo *parent_rel, Bitmapset *parent_cols)
Bitmapset * get_rel_all_updated_cols(PlannerInfo *root, RelOptInfo *rel)
static void expand_single_inheritance_child(PlannerInfo *root, RangeTblEntry *parentrte, Index parentRTindex, Relation parentrel, PlanRowMark *top_parentrc, Relation childrel, RangeTblEntry **childrte_p, Index *childRTindex_p)
void expand_inherited_rtentry(PlannerInfo *root, RelOptInfo *rel, RangeTblEntry *rte, Index rti)
bool restriction_is_always_true(PlannerInfo *root, RestrictInfo *restrictinfo)
void add_vars_to_targetlist(PlannerInfo *root, List *vars, Relids where_needed)
bool restriction_is_always_false(PlannerInfo *root, RestrictInfo *restrictinfo)
List * lappend(List *list, void *datum)
Alias * makeAlias(const char *aliasname, List *colnames)
Var * makeVar(int varno, AttrNumber varattno, Oid vartype, int32 vartypmod, Oid varcollid, Index varlevelsup)
Var * makeWholeRowVar(RangeTblEntry *rte, int varno, Index varlevelsup, bool allowScalar)
TargetEntry * makeTargetEntry(Expr *expr, AttrNumber resno, char *resname, bool resjunk)
List * make_ands_implicit(Expr *clause)
char * pstrdup(const char *in)
void * palloc0(Size size)
#define IsA(nodeptr, _type_)
RTEPermissionInfo * getRTEPermissionInfo(List *rteperminfos, RangeTblEntry *rte)
PartitionDesc PartitionDirectoryLookup(PartitionDirectory pdir, Relation rel)
Bitmapset * prune_append_rel_partitions(RelOptInfo *rel)
#define IS_SIMPLE_REL(rel)
#define planner_rt_fetch(rti, root)
#define IS_OTHER_REL(rel)
FormData_pg_attribute * Form_pg_attribute
List * find_all_inheritors(Oid parentrelId, LOCKMODE lockmode, List **numparents)
#define lfirst_node(type, lc)
static int list_length(const List *l)
static void * list_nth(const List *list, int n)
void get_relation_notnullatts(PlannerInfo *root, Relation relation)
Bitmapset * get_dependent_generated_columns(PlannerInfo *root, Index rti, Bitmapset *target_cols)
RowMarkType select_rowmark_type(RangeTblEntry *rte, LockClauseStrength strength)
static bool DatumGetBool(Datum X)
PlanRowMark * get_plan_rowmark(List *rowmarks, Index rtindex)
static struct subre * parse(struct vars *v, int stopper, int type, struct state *init, struct state *final)
#define RelationGetRelid(relation)
#define RelationGetDescr(relation)
#define RELATION_IS_OTHER_TEMP(relation)
RelOptInfo * find_base_rel(PlannerInfo *root, int relid)
void expand_planner_arrays(PlannerInfo *root, int add_size)
RelOptInfo * build_simple_rel(PlannerInfo *root, int relid, RelOptInfo *parent)
RestrictInfo * make_restrictinfo(PlannerInfo *root, Expr *clause, bool is_pushed_down, bool has_clone, bool is_clone, bool pseudoconstant, Index security_level, Relids required_relids, Relids incompatible_relids, Relids outer_relids)
void check_stack_depth(void)
LockClauseStrength strength
LockWaitPolicy waitPolicy
struct TableSampleClause * tablesample
Index baserestrict_min_security
#define FirstLowInvalidHeapAttributeNumber
#define TableOidAttributeNumber
#define SelfItemPointerAttributeNumber
Relation try_table_open(Oid relationId, LOCKMODE lockmode)
void table_close(Relation relation, LOCKMODE lockmode)
Relation table_open(Oid relationId, LOCKMODE lockmode)
static FormData_pg_attribute * TupleDescAttr(TupleDesc tupdesc, int i)
String * makeString(char *str)
bool contain_vars_of_level(Node *node, int levelsup)