⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 relation.h

📁 PostgreSQL 8.1.4的源码 适用于Linux下的开源数据库系统
💻 H
📖 第 1 页 / 共 3 页
字号:
/*------------------------------------------------------------------------- * * relation.h *	  Definitions for planner's internal data structures. * * * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * $PostgreSQL: pgsql/src/include/nodes/relation.h,v 1.119.2.1 2005/11/14 23:54:36 tgl Exp $ * *------------------------------------------------------------------------- */#ifndef RELATION_H#define RELATION_H#include "access/sdir.h"#include "nodes/bitmapset.h"#include "nodes/parsenodes.h"#include "storage/block.h"/* * Relids *		Set of relation identifiers (indexes into the rangetable). */typedef Bitmapset *Relids;/* * When looking for a "cheapest path", this enum specifies whether we want * cheapest startup cost or cheapest total cost. */typedef enum CostSelector{	STARTUP_COST, TOTAL_COST} CostSelector;/* * The cost estimate produced by cost_qual_eval() includes both a one-time * (startup) cost, and a per-tuple cost. */typedef struct QualCost{	Cost		startup;		/* one-time cost */	Cost		per_tuple;		/* per-evaluation cost */} QualCost;/*---------- * PlannerInfo *		Per-query information for planning/optimization * * This struct is conventionally called "root" in all the planner routines. * It holds links to all of the planner's working state, in addition to the * original Query.	Note that at present the planner extensively manipulates * the passed-in Query data structure; someday that should stop. *---------- */typedef struct PlannerInfo{	NodeTag		type;	Query	   *parse;			/* the Query being planned */	/*	 * base_rel_array holds pointers to "base rels" and "other rels" (see	 * comments for RelOptInfo for more info).	It is indexed by rangetable	 * index (so entry 0 is always wasted).  Entries can be NULL when an RTE	 * does not correspond to a base relation.	Note that the array may be	 * enlarged on-the-fly.	 */	struct RelOptInfo **base_rel_array; /* All one-relation RelOptInfos */	int			base_rel_array_size;	/* current allocated array len */	/*	 * join_rel_list is a list of all join-relation RelOptInfos we have	 * considered in this planning run.  For small problems we just scan the	 * list to do lookups, but when there are many join relations we build a	 * hash table for faster lookups.  The hash table is present and valid	 * when join_rel_hash is not NULL.	Note that we still maintain the list	 * even when using the hash table for lookups; this simplifies life for	 * GEQO.	 */	List	   *join_rel_list;	/* list of join-relation RelOptInfos */	struct HTAB *join_rel_hash; /* optional hashtable for join relations */	List	   *equi_key_list;	/* list of lists of equijoined PathKeyItems */	List	   *left_join_clauses;		/* list of RestrictInfos for outer										 * join clauses w/nonnullable var on										 * left */	List	   *right_join_clauses;		/* list of RestrictInfos for outer										 * join clauses w/nonnullable var on										 * right */	List	   *full_join_clauses;		/* list of RestrictInfos for full										 * outer join clauses */	List	   *in_info_list;	/* list of InClauseInfos */	List	   *query_pathkeys; /* desired pathkeys for query_planner(), and								 * actual pathkeys afterwards */	List	   *group_pathkeys; /* groupClause pathkeys, if any */	List	   *sort_pathkeys;	/* sortClause pathkeys, if any */	double		tuple_fraction; /* tuple_fraction passed to query_planner */	bool		hasJoinRTEs;	/* true if any RTEs are RTE_JOIN kind */	bool		hasOuterJoins;	/* true if any RTEs are outer joins */	bool		hasHavingQual;	/* true if havingQual was non-null */} PlannerInfo;/*---------- * RelOptInfo *		Per-relation information for planning/optimization * * For planning purposes, a "base rel" is either a plain relation (a table) * or the output of a sub-SELECT or function that appears in the range table. * In either case it is uniquely identified by an RT index.  A "joinrel" * is the joining of two or more base rels.  A joinrel is identified by * the set of RT indexes for its component baserels.  We create RelOptInfo * nodes for each baserel and joinrel, and store them in the PlannerInfo's * base_rel_array and join_rel_list respectively. * * Note that there is only one joinrel for any given set of component * baserels, no matter what order we assemble them in; so an unordered * set is the right datatype to identify it with. * * We also have "other rels", which are like base rels in that they refer to * single RT indexes; but they are not part of the join tree, and are given * a different RelOptKind to identify them. * * Currently the only kind of otherrels are those made for child relations * of an inheritance scan (SELECT FROM foo*).  The parent table's RTE and * corresponding baserel represent the whole result of the inheritance scan. * The planner creates separate RTEs and associated RelOptInfos for each child * table (including the parent table, in its capacity as a member of the * inheritance set).  These RelOptInfos are physically identical to baserels, * but are otherrels because they are not in the main join tree.  These added * RTEs and otherrels are used to plan the scans of the individual tables in * the inheritance set; then the parent baserel is given an Append plan * comprising the best plans for the individual child tables. * * At one time we also made otherrels to represent join RTEs, for use in * handling join alias Vars.  Currently this is not needed because all join * alias Vars are expanded to non-aliased form during preprocess_expression. * * Parts of this data structure are specific to various scan and join * mechanisms.	It didn't seem worth creating new node types for them. * *		relids - Set of base-relation identifiers; it is a base relation *				if there is just one, a join relation if more than one *		rows - estimated number of tuples in the relation after restriction *			   clauses have been applied (ie, output rows of a plan for it) *		width - avg. number of bytes per tuple in the relation after the *				appropriate projections have been done (ie, output width) *		reltargetlist - List of Var nodes for the attributes we need to *						output from this relation (in no particular order) *						NOTE: in a child relation, may contain RowExprs *		pathlist - List of Path nodes, one for each potentially useful *				   method of generating the relation *		cheapest_startup_path - the pathlist member with lowest startup cost *								(regardless of its ordering) *		cheapest_total_path - the pathlist member with lowest total cost *							  (regardless of its ordering) *		cheapest_unique_path - for caching cheapest path to produce unique *							   (no duplicates) output from relation * * If the relation is a base relation it will have these fields set: * *		relid - RTE index (this is redundant with the relids field, but *				is provided for convenience of access) *		rtekind - distinguishes plain relation, subquery, or function RTE *		min_attr, max_attr - range of valid AttrNumbers for rel *		attr_needed - array of bitmapsets indicating the highest joinrel *				in which each attribute is needed; if bit 0 is set then *				the attribute is needed as part of final targetlist *		attr_widths - cache space for per-attribute width estimates; *					  zero means not computed yet *		indexlist - list of IndexOptInfo nodes for relation's indexes *					(always NIL if it's not a table) *		pages - number of disk pages in relation (zero if not a table) *		tuples - number of tuples in relation (not considering restrictions) *		subplan - plan for subquery (NULL if it's not a subquery) * *		Note: for a subquery, tuples and subplan are not set immediately *		upon creation of the RelOptInfo object; they are filled in when *		set_base_rel_pathlist processes the object. * *		For otherrels that are inheritance children, these fields are filled *		in just as for a baserel. * * The presence of the remaining fields depends on the restrictions * and joins that the relation participates in: * *		baserestrictinfo - List of RestrictInfo nodes, containing info about *					each non-join qualification clause in which this relation *					participates (only used for base rels) *		baserestrictcost - Estimated cost of evaluating the baserestrictinfo *					clauses at a single tuple (only used for base rels) *		outerjoinset - For a base rel: if the rel appears within the nullable *					side of an outer join, the set of all relids *					participating in the highest such outer join; else NULL. *					Otherwise, unused. *		joininfo  - List of RestrictInfo nodes, containing info about each *					join clause in which this relation participates *		index_outer_relids - only used for base rels; set of outer relids *					that participate in indexable joinclauses for this rel *		index_inner_paths - only used for base rels; list of InnerIndexscanInfo *					nodes showing best indexpaths for various subsets of *					index_outer_relids. * * Note: Keeping a restrictinfo list in the RelOptInfo is useful only for * base rels, because for a join rel the set of clauses that are treated as * restrict clauses varies depending on which sub-relations we choose to join. * (For example, in a 3-base-rel join, a clause relating rels 1 and 2 must be * treated as a restrictclause if we join {1} and {2 3} to make {1 2 3}; but * if we join {1 2} and {3} then that clause will be a restrictclause in {1 2} * and should not be processed again at the level of {1 2 3}.)	Therefore, * the restrictinfo list in the join case appears in individual JoinPaths * (field joinrestrictinfo), not in the parent relation.  But it's OK for * the RelOptInfo to store the joininfo list, because that is the same * for a given rel no matter how we form it. * * We store baserestrictcost in the RelOptInfo (for base relations) because * we know we will need it at least once (to price the sequential scan) * and may need it multiple times to price index scans. * * outerjoinset is used to ensure correct placement of WHERE clauses that * apply to outer-joined relations; we must not apply such WHERE clauses * until after the outer join is performed. *---------- */typedef enum RelOptKind{	RELOPT_BASEREL,	RELOPT_JOINREL,	RELOPT_OTHER_CHILD_REL} RelOptKind;typedef struct RelOptInfo{	NodeTag		type;	RelOptKind	reloptkind;	/* all relations included in this RelOptInfo */	Relids		relids;			/* set of base relids (rangetable indexes) */	/* size estimates generated by planner */	double		rows;			/* estimated number of result tuples */	int			width;			/* estimated avg width of result tuples */	/* materialization information */	List	   *reltargetlist;	/* needed Vars */	List	   *pathlist;		/* Path structures */	struct Path *cheapest_startup_path;	struct Path *cheapest_total_path;	struct Path *cheapest_unique_path;	/* information about a base rel (not set for join rels!) */	Index		relid;	RTEKind		rtekind;		/* RELATION, SUBQUERY, or FUNCTION */	AttrNumber	min_attr;		/* smallest attrno of rel (often <0) */	AttrNumber	max_attr;		/* largest attrno of rel */	Relids	   *attr_needed;	/* array indexed [min_attr .. max_attr] */	int32	   *attr_widths;	/* array indexed [min_attr .. max_attr] */	List	   *indexlist;	BlockNumber pages;	double		tuples;	struct Plan *subplan;		/* if subquery */	/* used by various scans and joins: */	List	   *baserestrictinfo;		/* RestrictInfo structures (if base										 * rel) */	QualCost	baserestrictcost;		/* cost of evaluating the above */	Relids		outerjoinset;	/* set of base relids */	List	   *joininfo;		/* RestrictInfo structures for join clauses								 * involving this rel */	/* cached info about inner indexscan paths for relation: */	Relids		index_outer_relids;		/* other relids in indexable join

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -