mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-10-01 03:41:14 +02:00
7559d8ebfa
Backpatch-through: update all files in master, backpatch legal files through 9.4
78 lines
2.4 KiB
C
78 lines
2.4 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* plancat.h
|
|
* prototypes for plancat.c.
|
|
*
|
|
*
|
|
* Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*
|
|
* src/include/optimizer/plancat.h
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef PLANCAT_H
|
|
#define PLANCAT_H
|
|
|
|
#include "nodes/pathnodes.h"
|
|
#include "utils/relcache.h"
|
|
|
|
/* Hook for plugins to get control in get_relation_info() */
|
|
typedef void (*get_relation_info_hook_type) (PlannerInfo *root,
|
|
Oid relationObjectId,
|
|
bool inhparent,
|
|
RelOptInfo *rel);
|
|
extern PGDLLIMPORT get_relation_info_hook_type get_relation_info_hook;
|
|
|
|
|
|
extern void get_relation_info(PlannerInfo *root, Oid relationObjectId,
|
|
bool inhparent, RelOptInfo *rel);
|
|
|
|
extern List *infer_arbiter_indexes(PlannerInfo *root);
|
|
|
|
extern void estimate_rel_size(Relation rel, int32 *attr_widths,
|
|
BlockNumber *pages, double *tuples, double *allvisfrac);
|
|
|
|
extern int32 get_rel_data_width(Relation rel, int32 *attr_widths);
|
|
extern int32 get_relation_data_width(Oid relid, int32 *attr_widths);
|
|
|
|
extern bool relation_excluded_by_constraints(PlannerInfo *root,
|
|
RelOptInfo *rel, RangeTblEntry *rte);
|
|
|
|
extern List *build_physical_tlist(PlannerInfo *root, RelOptInfo *rel);
|
|
|
|
extern bool has_unique_index(RelOptInfo *rel, AttrNumber attno);
|
|
|
|
extern Selectivity restriction_selectivity(PlannerInfo *root,
|
|
Oid operatorid,
|
|
List *args,
|
|
Oid inputcollid,
|
|
int varRelid);
|
|
|
|
extern Selectivity join_selectivity(PlannerInfo *root,
|
|
Oid operatorid,
|
|
List *args,
|
|
Oid inputcollid,
|
|
JoinType jointype,
|
|
SpecialJoinInfo *sjinfo);
|
|
|
|
extern Selectivity function_selectivity(PlannerInfo *root,
|
|
Oid funcid,
|
|
List *args,
|
|
Oid inputcollid,
|
|
bool is_join,
|
|
int varRelid,
|
|
JoinType jointype,
|
|
SpecialJoinInfo *sjinfo);
|
|
|
|
extern void add_function_cost(PlannerInfo *root, Oid funcid, Node *node,
|
|
QualCost *cost);
|
|
|
|
extern double get_function_rows(PlannerInfo *root, Oid funcid, Node *node);
|
|
|
|
extern bool has_row_triggers(PlannerInfo *root, Index rti, CmdType event);
|
|
|
|
extern bool has_stored_generated_columns(PlannerInfo *root, Index rti);
|
|
|
|
#endif /* PLANCAT_H */
|