113#define LOG2(x) (log(x) / 0.693147180559945)
120#define APPEND_CPU_COST_MULTIPLIER 0.5
128#define MAXIMUM_ROWCOUNT 1e100
198 List **restrictlist);
200 int parallel_workers);
204static double page_size(
double tuples,
int width);
223 else if (nrows <= 1.0)
272 Cost startup_cost = 0;
306 startup_cost += path->pathtarget->cost.startup;
347 Cost startup_cost = 0;
353 spc_random_page_cost,
374 &spc_random_page_cost,
401 startup_cost += path->pathtarget->cost.startup;
402 run_cost += path->pathtarget->cost.per_tuple * path->
rows;
424 Cost startup_cost = 0;
465 Cost startup_cost = 0;
542 Cost startup_cost = 0;
545 Cost indexStartupCost;
548 double indexCorrelation,
551 spc_random_page_cost;
556 double tuples_fetched;
574 if (path->
path.param_info)
603 &indexStartupCost, &indexTotalCost,
604 &indexSelectivity, &indexCorrelation,
616 startup_cost += indexStartupCost;
617 run_cost += indexTotalCost - indexStartupCost;
624 &spc_random_page_cost,
666 (
double)
index->pages,
690 (
double)
index->pages,
706 (
double)
index->pages,
769 csquared = indexCorrelation * indexCorrelation;
787 startup_cost += path->
path.pathtarget->cost.startup;
833 if (rinfo->pseudoconstant)
838 result =
lappend(result, rinfo);
891 T = (pages > 1) ? (
double) pages : 1.0;
911 (2.0 *
T * tuples_fetched) / (2.0 *
T + tuples_fetched);
921 lim = (2.0 *
T *
b) / (2.0 *
T -
b);
922 if (tuples_fetched <=
lim)
925 (2.0 *
T * tuples_fetched) / (2.0 *
T + tuples_fetched);
930 b + (tuples_fetched -
lim) * (
T -
b) /
T;
956 foreach(l,
apath->bitmapquals)
965 foreach(l,
opath->bitmapquals)
1001 Cost startup_cost = 0;
1003 Cost indexTotalCost;
1008 double tuples_fetched;
1011 spc_random_page_cost;
1029 startup_cost += indexTotalCost;
1034 &spc_random_page_cost,
1083 startup_cost += path->pathtarget->cost.startup;
1084 run_cost += path->pathtarget->cost.per_tuple * path->
rows;
1100 *cost = ((
IndexPath *) path)->indextotalcost;
1235 Cost startup_cost = 0;
1242 double spc_random_page_cost;
1257 foreach(l, tidquals)
1298 &spc_random_page_cost,
1302 run_cost += spc_random_page_cost * ntuples;
1314 startup_cost += path->pathtarget->cost.startup;
1315 run_cost += path->pathtarget->cost.per_tuple * path->
rows;
1351 double spc_random_page_cost;
1380 ntuples = selectivity *
baserel->tuples;
1391 &spc_random_page_cost,
1413 startup_cost += path->pathtarget->cost.startup;
1513 startup_cost += path->
path.pathtarget->cost.startup;
1514 run_cost += path->
path.pathtarget->cost.per_tuple * path->
path.
rows;
1531 Cost startup_cost = 0;
1574 startup_cost += path->pathtarget->cost.startup;
1575 run_cost += path->pathtarget->cost.per_tuple * path->
rows;
1593 Cost startup_cost = 0;
1631 startup_cost += path->pathtarget->cost.startup;
1632 run_cost += path->pathtarget->cost.per_tuple * path->
rows;
1650 Cost startup_cost = 0;
1679 startup_cost += path->pathtarget->cost.startup;
1680 run_cost += path->pathtarget->cost.per_tuple * path->
rows;
1701 Cost startup_cost = 0;
1727 startup_cost += path->pathtarget->cost.startup;
1728 run_cost += path->pathtarget->cost.per_tuple * path->
rows;
1743 Cost startup_cost = 0;
1781 Cost startup_cost = 0;
1823 startup_cost =
nrterm->startup_cost;
1824 total_cost =
nrterm->total_cost;
1833 total_cost += 10 *
rterm->total_cost;
1844 runion->startup_cost = startup_cost;
1845 runion->total_cost = total_cost;
1848 rterm->pathtarget->width);
1889 double tuples,
int width,
1891 double limit_tuples)
1909 if (limit_tuples > 0 && limit_tuples < tuples)
1995 double limit_tuples)
2015 if (input_tuples < 2.0)
2043 foreach(l, pathkeys)
2047 linitial(key->pk_eclass->ec_members);
2111 path->
rows = input_tuples;
2138 double limit_tuples)
2151 path->
rows = tuples;
2186 foreach(cell, subpaths)
2244 apath->path.disabled_nodes = 0;
2245 apath->path.startup_cost = 0;
2246 apath->path.total_cost = 0;
2247 apath->path.rows = 0;
2252 if (!
apath->path.parallel_aware)
2256 if (pathkeys ==
NIL)
2270 foreach(l,
apath->subpaths)
2299 foreach(l,
apath->subpaths)
2332 apath->limit_tuples);
2345 apath->limit_tuples);
2367 foreach(l,
apath->subpaths)
2408 apath->path.total_cost +=
2410 apath->first_partial_path,
2411 apath->path.parallel_workers);
2418 apath->path.total_cost +=
2454 Cost startup_cost = 0;
2502 double tuples,
int width)
2509 path->
rows = tuples;
2564 double tuples =
mpath->subpath->rows;
2566 int width =
mpath->subpath->pathtarget->width;
2590 foreach(
lc,
mpath->param_exprs)
2609 ndistinct = est_calls;
2612 mpath->est_unique_keys = ndistinct;
2640 hit_ratio = ((est_calls - ndistinct) / est_calls) *
2749 startup_cost +=
aggcosts->transCost.startup;
2750 startup_cost +=
aggcosts->transCost.per_tuple * input_tuples;
2751 startup_cost +=
aggcosts->finalCost.startup;
2752 startup_cost +=
aggcosts->finalCost.per_tuple;
2765 total_cost +=
aggcosts->transCost.startup;
2766 total_cost +=
aggcosts->transCost.per_tuple * input_tuples;
2768 total_cost +=
aggcosts->finalCost.startup;
2769 total_cost +=
aggcosts->finalCost.per_tuple * numGroups;
2779 startup_cost +=
aggcosts->transCost.startup;
2780 startup_cost +=
aggcosts->transCost.per_tuple * input_tuples;
2783 startup_cost +=
aggcosts->finalCost.startup;
2785 total_cost = startup_cost;
2786 total_cost +=
aggcosts->finalCost.per_tuple * numGroups;
2811 double hashentrysize;
2829 nbatches =
Max((numGroups * hashentrysize) / mem_limit,
2833 num_partitions =
Max(num_partitions, 2);
2907 double input_tuples)
2920 double num_partitions;
2922 root->parse->targetList);
2943 root->parse->targetList);
3010 if (endOffset->constisnull)
3124 double input_tuples)
3148 foreach(
lc, windowFuncs)
3187 path->
rows = input_tuples;
3204 path->
startup_cost += (total_cost - startup_cost) / input_tuples *
3222 double input_tuples)
3295 Cost startup_cost = 0;
3300 Cost inner_run_cost;
3301 Cost inner_rescan_run_cost;
3305 disabled_nodes +=
inner_path->disabled_nodes;
3306 disabled_nodes +=
outer_path->disabled_nodes;
3347 run_cost += inner_run_cost;
3357 workspace->
total_cost = startup_cost + run_cost;
3394 if (path->
jpath.path.param_info)
3395 path->
jpath.path.rows = path->
jpath.path.param_info->ppi_rows;
3397 path->
jpath.path.rows = path->
jpath.path.parent->rows;
3400 if (path->
jpath.path.parallel_workers > 0)
3404 path->
jpath.path.rows =
3504 run_cost += inner_run_cost;
3534 startup_cost += path->
jpath.path.pathtarget->cost.startup;
3535 run_cost += path->
jpath.path.pathtarget->cost.per_tuple * path->
jpath.path.rows;
3537 path->
jpath.path.startup_cost = startup_cost;
3538 path->
jpath.path.total_cost = startup_cost + run_cost;
3578 List *outersortkeys,
List *innersortkeys,
3579 int outer_presorted_keys,
3583 Cost startup_cost = 0;
3587 Cost inner_run_cost;
3616 if (mergeclauses && jointype !=
JOIN_FULL)
3637 elog(
ERROR,
"left and right pathkeys do not match in mergejoin");
3688 Assert(outer_skip_rows <= outer_rows);
3689 Assert(inner_skip_rows <= inner_rows);
3726 outer_presorted_keys,
3750 disabled_nodes +=
sort_path.disabled_nodes;
3759 disabled_nodes +=
outer_path->disabled_nodes;
3791 disabled_nodes +=
sort_path.disabled_nodes;
3800 disabled_nodes +=
inner_path->disabled_nodes;
3821 workspace->
total_cost = startup_cost + run_cost + inner_run_cost;
3892 if (path->
jpath.path.param_info)
3893 path->
jpath.path.rows = path->
jpath.path.param_info->ppi_rows;
3895 path->
jpath.path.rows = path->
jpath.path.parent->rows;
3898 if (path->
jpath.path.parallel_workers > 0)
3902 path->
jpath.path.rows =
4037 else if (innersortkeys ==
NIL &&
4075 (outer_skip_rows + inner_skip_rows *
rescanratio);
4077 ((outer_rows - outer_skip_rows) +
4094 startup_cost += path->
jpath.path.pathtarget->cost.startup;
4095 run_cost += path->
jpath.path.pathtarget->cost.per_tuple * path->
jpath.path.rows;
4097 path->
jpath.path.startup_cost = startup_cost;
4098 path->
jpath.path.total_cost = startup_cost + run_cost;
4116 foreach(
lc, rinfo->scansel_cache)
4150 rinfo->scansel_cache =
lappend(rinfo->scansel_cache, cache);
4192 Cost startup_cost = 0;
4201 size_t space_allowed;
4205 disabled_nodes +=
inner_path->disabled_nodes;
4206 disabled_nodes +=
outer_path->disabled_nodes;
4279 workspace->
total_cost = startup_cost + run_cost;
4326 if (path->
jpath.path.param_info)
4327 path->
jpath.path.rows = path->
jpath.path.param_info->ppi_rows;
4329 path->
jpath.path.rows = path->
jpath.path.parent->rows;
4332 if (path->
jpath.path.parallel_workers > 0)
4336 path->
jpath.path.rows =
4544 startup_cost += path->
jpath.path.pathtarget->cost.startup;
4545 run_cost += path->
jpath.path.pathtarget->cost.per_tuple * path->
jpath.path.rows;
4547 path->
jpath.path.startup_cost = startup_cost;
4548 path->
jpath.path.total_cost = startup_cost + run_cost;
4691 if (((
HashPath *) path)->num_batches == 1)
4715 path->pathtarget->width);
4742 path->pathtarget->width);
4800 *cost = context.
total;
4818 *cost = context.
total;
4837 if (rinfo->eval_cost.startup < 0)
4849 if (rinfo->orclause)
4858 if (rinfo->pseudoconstant)
5032 elog(
ERROR,
"cannot handle unplanned sub-select");
5166 foreach(l, restrictlist)
5355 tuples =
selec * outer_tuples * inner_tuples;
5426 if (nrows > rel->
rows)
5512 if (nrows > rel->
rows)
5575 foreach(l, restrictlist)
5631 if (nrows < outer_rows)
5637 if (nrows < outer_rows)
5639 if (nrows < inner_rows)
5653 elog(
ERROR,
"unrecognized join type: %d", (
int) jointype);
5681 List **restrictlist)
5689 foreach(
lc,
root->fkey_list)
5744 if (rinfo->parent_ec)
5759 if (
fkinfo->eclass[
i] == rinfo->parent_ec)
5883 if (
fkinfo->nconst_ec > 0)
6024 foreach(
lc,
rte->functions)
6110 if (
rte->self_reference)
6258 ((
Var *) node)->varno == rel->
relid)
6283 if (rel->attr_widths[
ndx] > 0)
6437 const Var *var = (
const Var *) expr;
6444 var->
varno <
root->simple_rel_array_size)
6454 if (rel->attr_widths[
ndx] > 0)
6455 return rel->attr_widths[
ndx];
6544 Cost indexTotalCost;
6548 double tuples_fetched;
6570 pages_fetched = (2.0 *
T * tuples_fetched) / (2.0 *
T + tuples_fetched);
6625 if (lossy_pages > 0)
6633 *
cost_p = indexTotalCost;
int compute_parallel_worker(RelOptInfo *rel, double heap_pages, double index_pages, int max_workers)
void(* amcostestimate_function)(PlannerInfo *root, IndexPath *path, double loop_count, Cost *indexStartupCost, Cost *indexTotalCost, Selectivity *indexSelectivity, double *indexCorrelation, double *indexPages)
bool bms_is_subset(const Bitmapset *a, const Bitmapset *b)
bool bms_is_member(int x, const Bitmapset *a)
BMS_Membership bms_membership(const Bitmapset *a)
#define Assert(condition)
#define OidIsValid(objectId)
double expression_returns_set_rows(PlannerInfo *root, Node *clause)
Selectivity clauselist_selectivity(PlannerInfo *root, List *clauses, int varRelid, JoinType jointype, SpecialJoinInfo *sjinfo)
Selectivity clause_selectivity(PlannerInfo *root, Node *clause, int varRelid, JoinType jointype, SpecialJoinInfo *sjinfo)
#define DEFAULT_PARALLEL_TUPLE_COST
#define DEFAULT_PARALLEL_SETUP_COST
#define DEFAULT_CPU_INDEX_TUPLE_COST
#define DEFAULT_CPU_TUPLE_COST
#define DEFAULT_RANDOM_PAGE_COST
#define DEFAULT_RECURSIVE_WORKTABLE_FACTOR
#define DEFAULT_EFFECTIVE_CACHE_SIZE
#define DEFAULT_SEQ_PAGE_COST
#define DEFAULT_CPU_OPERATOR_COST
#define APPEND_CPU_COST_MULTIPLIER
void set_namedtuplestore_size_estimates(PlannerInfo *root, RelOptInfo *rel)
static double get_windowclause_startup_tuples(PlannerInfo *root, WindowClause *wc, double input_tuples)
bool enable_partitionwise_aggregate
void final_cost_hashjoin(PlannerInfo *root, HashPath *path, JoinCostWorkspace *workspace, JoinPathExtraData *extra)
double index_pages_fetched(double tuples_fetched, BlockNumber pages, double index_pages, PlannerInfo *root)
void cost_bitmap_tree_node(Path *path, Cost *cost, Selectivity *selec)
double get_parameterized_baserel_size(PlannerInfo *root, RelOptInfo *rel, List *param_clauses)
static void get_restriction_qual_cost(PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info, QualCost *qpqual_cost)
static double page_size(double tuples, int width)
int max_parallel_workers_per_gather
double get_parameterized_joinrel_size(PlannerInfo *root, RelOptInfo *rel, Path *outer_path, Path *inner_path, SpecialJoinInfo *sjinfo, List *restrict_clauses)
void final_cost_mergejoin(PlannerInfo *root, MergePath *path, JoinCostWorkspace *workspace, JoinPathExtraData *extra)
static List * extract_nonindex_conditions(List *qual_clauses, List *indexclauses)
static void set_rel_width(PlannerInfo *root, RelOptInfo *rel)
void compute_semi_anti_join_factors(PlannerInfo *root, RelOptInfo *joinrel, RelOptInfo *outerrel, RelOptInfo *innerrel, JoinType jointype, SpecialJoinInfo *sjinfo, List *restrictlist, SemiAntiJoinFactors *semifactors)
static double get_indexpath_pages(Path *bitmapqual)
double parallel_setup_cost
static bool cost_qual_eval_walker(Node *node, cost_qual_eval_context *context)
void set_baserel_size_estimates(PlannerInfo *root, RelOptInfo *rel)
void cost_windowagg(Path *path, PlannerInfo *root, List *windowFuncs, WindowClause *winclause, int input_disabled_nodes, Cost input_startup_cost, Cost input_total_cost, double input_tuples)
double recursive_worktable_factor
void cost_functionscan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info)
void cost_material(Path *path, int input_disabled_nodes, Cost input_startup_cost, Cost input_total_cost, double tuples, int width)
void cost_bitmap_heap_scan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info, Path *bitmapqual, double loop_count)
void cost_tidrangescan(Path *path, PlannerInfo *root, RelOptInfo *baserel, List *tidrangequals, ParamPathInfo *param_info)
static double relation_byte_size(double tuples, int width)
double parallel_tuple_cost
void set_function_size_estimates(PlannerInfo *root, RelOptInfo *rel)
void cost_agg(Path *path, PlannerInfo *root, AggStrategy aggstrategy, const AggClauseCosts *aggcosts, int numGroupCols, double numGroups, List *quals, int disabled_nodes, Cost input_startup_cost, Cost input_total_cost, double input_tuples, double input_width)
void cost_sort(Path *path, PlannerInfo *root, List *pathkeys, int input_disabled_nodes, Cost input_cost, double tuples, int width, Cost comparison_cost, int sort_mem, double limit_tuples)
static double calc_joinrel_size_estimate(PlannerInfo *root, RelOptInfo *joinrel, RelOptInfo *outer_rel, RelOptInfo *inner_rel, double outer_rows, double inner_rows, SpecialJoinInfo *sjinfo, List *restrictlist)
static MergeScanSelCache * cached_scansel(PlannerInfo *root, RestrictInfo *rinfo, PathKey *pathkey)
static void cost_rescan(PlannerInfo *root, Path *path, Cost *rescan_startup_cost, Cost *rescan_total_cost)
bool enable_indexonlyscan
void final_cost_nestloop(PlannerInfo *root, NestPath *path, JoinCostWorkspace *workspace, JoinPathExtraData *extra)
void cost_gather_merge(GatherMergePath *path, PlannerInfo *root, RelOptInfo *rel, ParamPathInfo *param_info, int input_disabled_nodes, Cost input_startup_cost, Cost input_total_cost, double *rows)
void cost_recursive_union(Path *runion, Path *nrterm, Path *rterm)
static void cost_tuplesort(Cost *startup_cost, Cost *run_cost, double tuples, int width, Cost comparison_cost, int sort_mem, double limit_tuples)
void cost_tablefuncscan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info)
void initial_cost_hashjoin(PlannerInfo *root, JoinCostWorkspace *workspace, JoinType jointype, List *hashclauses, Path *outer_path, Path *inner_path, JoinPathExtraData *extra, bool parallel_hash)
void initial_cost_mergejoin(PlannerInfo *root, JoinCostWorkspace *workspace, JoinType jointype, List *mergeclauses, Path *outer_path, Path *inner_path, List *outersortkeys, List *innersortkeys, int outer_presorted_keys, JoinPathExtraData *extra)
void cost_samplescan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info)
void cost_gather(GatherPath *path, PlannerInfo *root, RelOptInfo *rel, ParamPathInfo *param_info, double *rows)
void set_cte_size_estimates(PlannerInfo *root, RelOptInfo *rel, double cte_rows)
void set_joinrel_size_estimates(PlannerInfo *root, RelOptInfo *rel, RelOptInfo *outer_rel, RelOptInfo *inner_rel, SpecialJoinInfo *sjinfo, List *restrictlist)
void cost_append(AppendPath *apath, PlannerInfo *root)
double compute_gather_rows(Path *path)
void cost_qual_eval_node(QualCost *cost, Node *qual, PlannerInfo *root)
void cost_namedtuplestorescan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info)
void cost_seqscan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info)
PathTarget * set_pathtarget_cost_width(PlannerInfo *root, PathTarget *target)
void cost_valuesscan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info)
void cost_incremental_sort(Path *path, PlannerInfo *root, List *pathkeys, int presorted_keys, int input_disabled_nodes, Cost input_startup_cost, Cost input_total_cost, double input_tuples, int width, Cost comparison_cost, int sort_mem, double limit_tuples)
void cost_qual_eval(QualCost *cost, List *quals, PlannerInfo *root)
bool enable_presorted_aggregate
void initial_cost_nestloop(PlannerInfo *root, JoinCostWorkspace *workspace, JoinType jointype, Path *outer_path, Path *inner_path, JoinPathExtraData *extra)
void set_result_size_estimates(PlannerInfo *root, RelOptInfo *rel)
static bool has_indexed_join_quals(NestPath *path)
bool enable_parallel_hash
bool enable_partitionwise_join
void cost_group(Path *path, PlannerInfo *root, int numGroupCols, double numGroups, List *quals, int input_disabled_nodes, Cost input_startup_cost, Cost input_total_cost, double input_tuples)
void cost_resultscan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info)
static Cost append_nonpartial_cost(List *subpaths, int numpaths, int parallel_workers)
double compute_bitmap_pages(PlannerInfo *root, RelOptInfo *baserel, Path *bitmapqual, double loop_count, Cost *cost_p, double *tuples_p)
void cost_bitmap_and_node(BitmapAndPath *path, PlannerInfo *root)
void set_subquery_size_estimates(PlannerInfo *root, RelOptInfo *rel)
bool enable_parallel_append
void set_foreign_size_estimates(PlannerInfo *root, RelOptInfo *rel)
void cost_tidscan(Path *path, PlannerInfo *root, RelOptInfo *baserel, List *tidquals, ParamPathInfo *param_info)
static double approx_tuple_count(PlannerInfo *root, JoinPath *path, List *quals)
void cost_subplan(PlannerInfo *root, SubPlan *subplan, Plan *plan)
static void cost_memoize_rescan(PlannerInfo *root, MemoizePath *mpath, Cost *rescan_startup_cost, Cost *rescan_total_cost)
void cost_merge_append(Path *path, PlannerInfo *root, List *pathkeys, int n_streams, int input_disabled_nodes, Cost input_startup_cost, Cost input_total_cost, double tuples)
double clamp_row_est(double nrows)
static double get_parallel_divisor(Path *path)
void cost_subqueryscan(SubqueryScanPath *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info, bool trivial_pathtarget)
void cost_ctescan(Path *path, PlannerInfo *root, RelOptInfo *baserel, ParamPathInfo *param_info)
void cost_bitmap_or_node(BitmapOrPath *path, PlannerInfo *root)
bool enable_partition_pruning
int32 clamp_width_est(int64 tuple_width)
double cpu_index_tuple_cost
void set_tablefunc_size_estimates(PlannerInfo *root, RelOptInfo *rel)
void cost_index(IndexPath *path, PlannerInfo *root, double loop_count, bool partial_path)
void set_values_size_estimates(PlannerInfo *root, RelOptInfo *rel)
static Selectivity get_foreign_key_join_selectivity(PlannerInfo *root, Relids outer_relids, Relids inner_relids, SpecialJoinInfo *sjinfo, List **restrictlist)
bool enable_incremental_sort
static int32 get_expr_width(PlannerInfo *root, const Node *expr)
bool is_redundant_with_indexclauses(RestrictInfo *rinfo, List *indexclauses)
RestrictInfo * find_derived_clause_for_ec_member(PlannerInfo *root, EquivalenceClass *ec, EquivalenceMember *em)
bool ExecSupportsMarkRestore(Path *pathnode)
bool ExecMaterializesOutput(NodeTag plantype)
#define palloc_object(type)
#define palloc_array(type, count)
#define SizeofHeapTupleHeader
void init_dummy_sjinfo(SpecialJoinInfo *sjinfo, Relids left_relids, Relids right_relids)
List * lappend(List *list, void *datum)
List * list_concat(List *list1, const List *list2)
List * list_concat_copy(const List *list1, const List *list2)
List * list_copy(const List *oldlist)
bool list_member_ptr(const List *list, const void *datum)
void list_free(List *list)
void getTypeOutputInfo(Oid type, Oid *typOutput, bool *typIsVarlena)
int32 get_attavgwidth(Oid relid, AttrNumber attnum)
RegProcedure get_opcode(Oid opno)
void getTypeInputInfo(Oid type, Oid *typInput, Oid *typIOParam)
int32 get_typavgwidth(Oid typid, int32 typmod)
Datum subpath(PG_FUNCTION_ARGS)
List * make_ands_implicit(Expr *clause)
static const uint32 T[65]
Size hash_agg_entry_size(int numTrans, Size tupleWidth, Size transitionSpace)
void hash_agg_set_limits(double hashentrysize, double input_groups, int used_bits, Size *mem_limit, uint64 *ngroups_limit, int *num_partitions)
Oid exprType(const Node *expr)
int32 exprTypmod(const Node *expr)
void set_sa_opfuncid(ScalarArrayOpExpr *opexpr)
void set_opfuncid(OpExpr *opexpr)
static Node * get_rightop(const void *clause)
#define expression_tree_walker(n, w, c)
static Node * get_leftop(const void *clause)
void ExecChooseHashTableSize(double ntuples, int tupwidth, bool useskew, bool try_combined_hash_mem, int parallel_workers, size_t *space_allowed, int *numbuckets, int *numbatches, int *num_skew_mcvs)
size_t get_hash_memory_limit(void)
double ExecEstimateCacheEntryOverheadBytes(double ntuples)
#define IsA(nodeptr, _type_)
#define IS_OUTER_JOIN(jointype)
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
#define FRAMEOPTION_END_CURRENT_ROW
#define FRAMEOPTION_END_OFFSET_PRECEDING
#define FRAMEOPTION_END_OFFSET_FOLLOWING
#define FRAMEOPTION_RANGE
#define FRAMEOPTION_GROUPS
#define FRAMEOPTION_END_UNBOUNDED_FOLLOWING
bool pathkeys_count_contained_in(List *keys1, List *keys2, int *n_common)
bool pathkeys_contained_in(List *keys1, List *keys2)
#define RINFO_IS_PUSHED_DOWN(rinfo, joinrelids)
#define planner_rt_fetch(rti, root)
#define RELATION_WAS_MADE_UNIQUE(rel, sjinfo, nominal_jointype)
#define lfirst_node(type, lc)
static int list_length(const List *l)
#define foreach_current_index(var_or_cell)
#define foreach_delete_current(lst, var_or_cell)
#define for_each_cell(cell, lst, initcell)
static ListCell * list_head(const List *l)
PlaceHolderInfo * find_placeholder_info(PlannerInfo *root, PlaceHolderVar *phv)
void add_function_cost(PlannerInfo *root, Oid funcid, Node *node, QualCost *cost)
int32 get_relation_data_width(Oid relid, int32 *attr_widths)
bool parallel_leader_participation
static int64 DatumGetInt64(Datum X)
static int16 DatumGetInt16(Datum X)
static int32 DatumGetInt32(Datum X)
#define IS_SPECIAL_VARNO(varno)
RelOptInfo * find_base_rel(PlannerInfo *root, int relid)
RelOptInfo * fetch_upper_rel(PlannerInfo *root, UpperRelationKind kind, Relids relids)
bool join_clause_is_movable_into(RestrictInfo *rinfo, Relids currentrelids, Relids current_and_outer)
void mergejoinscansel(PlannerInfo *root, Node *clause, Oid opfamily, CompareType cmptype, bool nulls_first, Selectivity *leftstart, Selectivity *leftend, Selectivity *rightstart, Selectivity *rightend)
double estimate_array_length(PlannerInfo *root, Node *arrayexpr)
double estimate_num_groups(PlannerInfo *root, List *groupExprs, double input_rows, List **pgset, EstimationInfo *estinfo)
List * estimate_multivariate_bucketsize(PlannerInfo *root, RelOptInfo *inner, List *hashclauses, Selectivity *innerbucketsize)
void estimate_hash_bucket_stats(PlannerInfo *root, Node *hashkey, double nbuckets, Selectivity *mcv_freq, Selectivity *bucketsize_frac)
#define CLAMP_PROBABILITY(p)
#define DEFAULT_NUM_DISTINCT
#define SELFLAG_USED_DEFAULT
void get_tablespace_page_costs(Oid spcid, double *spc_random_page_cost, double *spc_seq_page_cost)
Selectivity bitmapselectivity
Selectivity bitmapselectivity
Cardinality inner_rows_total
Selectivity indexselectivity
Cost inner_rescan_run_cost
Cardinality inner_skip_rows
Cardinality inner_rows_total
Cardinality outer_skip_rows
Selectivity rightstartsel
struct PathTarget * reltarget
QualCost baserestrictcost
Selectivity outer_match_frac
TsmRoutine * GetTsmRoutine(Oid tsmhandler)
int tbm_calculate_entries(Size maxbytes)
List * get_sortgrouplist_exprs(List *sgClauses, List *targetList)
int tuplesort_merge_order(int64 allowedMem)
Relids pull_varnos(PlannerInfo *root, Node *node)