primnodes.h 10.2 KB
Newer Older
1 2
/*-------------------------------------------------------------------------
 *
3
 * primnodes.h
4
 *	  Definitions for parse tree/query tree ("primitive") nodes.
5 6 7 8
 *
 *
 * Copyright (c) 1994, Regents of the University of California
 *
9
 * $Id: primnodes.h,v 1.26 1999/05/12 15:02:07 wieck Exp $
10 11 12 13
 *
 *-------------------------------------------------------------------------
 */
#ifndef PRIMNODES_H
14
#define PRIMNODES_H
15

16 17 18
#include <utils/fcache.h>
#include <access/attnum.h>
#include <nodes/pg_list.h>
19 20

/* ----------------------------------------------------------------
21
 *						node definitions
22 23 24 25 26
 * ----------------------------------------------------------------
 */

/* ----------------
 * Resdom (Result Domain)
27 28
 *		resno			- attribute number
 *		restype			- type of the resdom
29
 *		restypmod		- type-specific modifier of the result
30 31 32
 *		resname			- name of the resdom (could be NULL)
 *		reskey			- order of key in a sort (for those > 0)
 *		reskeyop		- sort operator Oid
33
 *		resgroupref		- set to nonzero if referenced from a group by clause
34 35 36
 *		resjunk			- set to nonzero to eliminate the attribute
 *						  from final target list  e.g., ctid for replace
 *						  and delete
37 38 39
 *
 * ----------------
 */
40 41
typedef struct Resdom
{
42 43 44
	NodeTag		type;
	AttrNumber	resno;
	Oid			restype;
45
	int32		restypmod;
46 47 48
	char	   *resname;
	Index		reskey;
	Oid			reskeyop;
49
	Index		resgroupref;
50
	int			resjunk;
51
} Resdom;
52 53 54

/* -------------
 * Fjoin
55 56 57 58 59 60 61 62 63 64 65 66 67 68
 *		initialized		- true if the Fjoin has already been initialized for
 *						  the current target list evaluation
 *		nNodes			- The number of Iter nodes returning sets that the
 *						  node will flatten
 *		outerList		- 1 or more Iter nodes
 *		inner			- exactly one Iter node.  We eval every node in the
 *						  outerList once then eval the inner node to completion
 *						  pair the outerList result vector with each inner
 *						  result to form the full result.  When the inner has
 *						  been exhausted, we get the next outer result vector
 *						  and reset the inner.
 *		results			- The complete (flattened) result vector
 *		alwaysNull		- a null vector to indicate sets with a cardinality of
 *						  0, we treat them as the set {NULL}.
69
 */
70 71
typedef struct Fjoin
{
72 73 74 75 76 77
	NodeTag		type;
	bool		fj_initialized;
	int			fj_nNodes;
	List	   *fj_innerNode;
	DatumPtr	fj_results;
	BoolPtr		fj_alwaysDone;
78
} Fjoin;
79 80 81

/* ----------------
 * Expr
82 83 84 85 86
 *		typeOid			- oid of the type of this expression
 *		opType			- type of this expression
 *		oper			- the Oper node if it is an OPER_EXPR or the
 *						  Func node if it is a FUNC_EXPR
 *		args			- arguments to this expression
87 88
 * ----------------
 */
89 90
typedef enum OpType
{
91
	OP_EXPR, FUNC_EXPR, OR_EXPR, AND_EXPR, NOT_EXPR, SUBPLAN_EXPR
92
} OpType;
93

94 95
typedef struct Expr
{
96 97 98
	NodeTag		type;
	Oid			typeOid;		/* oid of the type of this expr */
	OpType		opType;			/* type of the op */
99
	Node	   *oper;			/* could be Oper or Func or SubPlan */
100
	List	   *args;			/* list of argument nodes */
101
} Expr;
102 103 104

/* ----------------
 * Var
105 106 107 108
 *		varno			- index of this var's relation in the range table
 *						  (could be INNER or OUTER)
 *		varattno		- attribute number of this var, or zero for all
 *		vartype			- pg_type tuple oid for the type of this var
109
 *		vartypmod		- pg_attribute typmod value
110
 *		varlevelsup		- for subquery variables referencing outer relations
111 112 113 114
 *		varnoold		- keep varno around in case it got changed to INNER/
 *						  OUTER (see match_varid)
 *		varoattno		- attribute number of this var
 *						  [ '(varnoold varoattno) was varid   -ay 2/95]
115 116
 * ----------------
 */
117 118
#define    INNER		65000
#define    OUTER		65001
119

120 121
#define    PRS2_CURRENT_VARNO			1
#define    PRS2_NEW_VARNO				2
122

123 124
typedef struct Var
{
125 126 127 128
	NodeTag		type;
	Index		varno;
	AttrNumber	varattno;
	Oid			vartype;
129
	int32		vartypmod;
130
	Index		varlevelsup;	/* erased by upper optimizer */
131 132
	Index		varnoold;		/* only used by optimizer */
	AttrNumber	varoattno;		/* only used by optimizer */
133
} Var;
134 135 136

/* ----------------
 * Oper
137 138 139 140 141
 *		opno			- PG_OPERATOR OID of the operator
 *		opid			- PG_PROC OID for the operator
 *		opresulttype	- PG_TYPE OID of the operator's return value
 *		opsize			- size of return result (cached by executor)
 *		op_fcache		- XXX comment me.
142 143 144
 *
 * ----
 * NOTE: in the good old days 'opno' used to be both (or either, or
145
 * neither) the pg_operator oid, and/or the pg_proc oid depending
146 147 148 149 150 151
 * on the postgres module in question (parser->pg_operator,
 * executor->pg_proc, planner->both), the mood of the programmer,
 * and the phase of the moon (rumors that it was also depending on the day
 * of the week are probably false). To make things even more postgres-like
 * (i.e. a mess) some comments were referring to 'opno' using the name
 * 'opid'. Anyway, now we have two separate fields, and of course that
152
 * immediately removes all bugs from the code...		[ sp :-) ].
153 154
 * ----------------
 */
155 156
typedef struct Oper
{
157 158 159 160 161
	NodeTag		type;
	Oid			opno;
	Oid			opid;
	Oid			opresulttype;
	int			opsize;
162
	FunctionCachePtr op_fcache;
163
} Oper;
164 165 166 167


/* ----------------
 * Const
168 169 170 171 172 173 174 175 176 177 178 179
 *		consttype - PG_TYPE OID of the constant's value
 *		constlen - length in bytes of the constant's value
 *		constvalue - the constant's value
 *		constisnull - whether the constant is null
 *				(if true, the other fields are undefined)
 *		constbyval - whether the information in constvalue
 *				if passed by value.  If true, then all the information
 *				is stored in the datum. If false, then the datum
 *				contains a pointer to the information.
 *		constisset - whether the const represents a set.  The const
 *				value corresponding will be the query that defines
 *				the set.
180 181
 * ----------------
 */
182 183
typedef struct Const
{
184 185
	NodeTag		type;
	Oid			consttype;
186
	int			constlen;
187 188 189 190 191
	Datum		constvalue;
	bool		constisnull;
	bool		constbyval;
	bool		constisset;
	bool		constiscast;
192
} Const;
193 194 195

/* ----------------
 * Param
196 197
 *		paramkind - specifies the kind of parameter. The possible values
 *		for this field are specified in "params.h", and they are:
198
 *
199 200 201
 *		PARAM_NAMED: The parameter has a name, i.e. something
 *				like `$.salary' or `$.foobar'.
 *				In this case field `paramname' must be a valid Name.
202
 *
203 204 205
 *		PARAM_NUM:	 The parameter has only a numeric identifier,
 *				i.e. something like `$1', `$2' etc.
 *				The number is contained in the `paramid' field.
206
 *
207 208 209 210
 *		PARAM_NEW:	 Used in PRS2 rule, similar to PARAM_NAMED.
 *					 The `paramname' and `paramid' refer to the "NEW" tuple
 *					 The `pramname' is the attribute name and `paramid'
 *					 is the attribute number.
211
 *
212 213
 *		PARAM_OLD:	 Same as PARAM_NEW, but in this case we refer to
 *				the "OLD" tuple.
214
 *
215 216 217 218
 *		paramid - numeric identifier for literal-constant parameters ("$1")
 *		paramname - attribute name for tuple-substitution parameters ("$.foo")
 *		paramtype - PG_TYPE OID of the parameter's value
 *		param_tlist - allows for projection in a param node.
219 220
 * ----------------
 */
221 222
typedef struct Param
{
223 224 225 226 227 228
	NodeTag		type;
	int			paramkind;
	AttrNumber	paramid;
	char	   *paramname;
	Oid			paramtype;
	List	   *param_tlist;
229
} Param;
230 231 232 233


/* ----------------
 * Func
234 235 236 237 238 239 240 241 242 243 244
 *		funcid			- PG_FUNCTION OID of the function
 *		functype		- PG_TYPE OID of the function's return value
 *		funcisindex		- the function can be evaluated by scanning an index
 *						  (set during query optimization)
 *		funcsize		- size of return result (cached by executor)
 *		func_fcache		- runtime state while running this function.  Where
 *						  we are in the execution of the function if it
 *						  returns more than one value, etc.
 *						  See utils/fcache.h
 *		func_tlist		- projection of functions returning tuples
 *		func_planlist	- result of planning this func, if it's a PQ func
245 246
 * ----------------
 */
247 248
typedef struct Func
{
249 250 251 252 253
	NodeTag		type;
	Oid			funcid;
	Oid			functype;
	bool		funcisindex;
	int			funcsize;
254
	FunctionCachePtr func_fcache;
255 256
	List	   *func_tlist;
	List	   *func_planlist;
257
} Func;
258 259

/* ----------------
B
Bruce Momjian 已提交
260
 * Aggref
261 262 263
 *		aggname			- name of the aggregate
 *		basetype		- base type Oid of the aggregate
 *		aggtype			- type Oid of final result of the aggregate
264 265
 *		target			- attribute or expression we are aggregating on
 *		aggno			- index to ecxt_values
266 267
 * ----------------
 */
B
Bruce Momjian 已提交
268
typedef struct Aggref
269
{
270 271
	NodeTag		type;
	char	   *aggname;
272 273
	Oid			basetype;
	Oid			aggtype;
274
	Node	   *target;
275 276
	int			aggno;
	bool		usenulls;
B
Bruce Momjian 已提交
277
} Aggref;
278

279 280 281 282 283 284 285 286 287 288 289
/* ----------------
 * SubLink
 *		subLinkType		- EXISTS, ALL, ANY, EXPR
 *		useor			- TRUE for <>
 *		lefthand		- list of Var/Const nodes on the left
 *		oper			- list of Oper nodes
 *		subselect		- subselect as Query* or parsetree
 * ----------------
 */
typedef enum SubLinkType
{
290
	EXISTS_SUBLINK, ALL_SUBLINK, ANY_SUBLINK, EXPR_SUBLINK
291 292 293 294 295 296
} SubLinkType;


typedef struct SubLink
{
	NodeTag		type;
297
	SubLinkType subLinkType;
298
	bool		useor;
299 300 301
	List	   *lefthand;
	List	   *oper;
	Node	   *subselect;
302 303
} SubLink;

304 305
/* ----------------
 * Array
306 307 308 309 310 311 312
 *		arrayelemtype	- base type of the array's elements (homogenous!)
 *		arrayelemlength - length of that type
 *		arrayelembyval	- can you pass this element by value?
 *		arrayndim		- number of dimensions of the array
 *		arraylow		- base for array indexing
 *		arrayhigh		- limit for array indexing
 *		arraylen		-
313 314
 * ----------------
 *
315 316 317
 *	memo from mao:	the array support we inherited from 3.1 is just
 *	wrong.	when time exists, we should redesign this stuff to get
 *	around a bunch of unfortunate implementation decisions made there.
318
 */
319 320
typedef struct Array
{
321 322 323 324 325 326 327 328
	NodeTag		type;
	Oid			arrayelemtype;
	int			arrayelemlength;
	bool		arrayelembyval;
	int			arrayndim;
	IntArray	arraylow;
	IntArray	arrayhigh;
	int			arraylen;
B
Bruce Momjian 已提交
329
} Array;
330 331

/* ----------------
332 333 334 335 336 337 338 339 340
 *	ArrayRef:
 *		refelemtype		- type of the element referenced here
 *		refelemlength	- length of that type
 *		refelembyval	- can you pass this element type by value?
 *		refupperindexpr - expressions that evaluate to upper array index
 *		reflowerexpr- the expressions that evaluate to a lower array index
 *		refexpr			- the expression that evaluates to an array
 *		refassignexpr- the expression that evaluates to the new value
 *	to be assigned to the array in case of replace.
341 342
 * ----------------
 */
343 344
typedef struct ArrayRef
{
345 346 347 348 349 350 351 352 353
	NodeTag		type;
	int			refattrlength;
	int			refelemlength;
	Oid			refelemtype;
	bool		refelembyval;
	List	   *refupperindexpr;
	List	   *reflowerindexpr;
	Node	   *refexpr;
	Node	   *refassgnexpr;
B
Bruce Momjian 已提交
354
} ArrayRef;
355

356
#endif	 /* PRIMNODES_H */