1 /*-------------------------------------------------------------------------
4 * support for the POSTGRES executor module
7 * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
8 * Portions Copyright (c) 1994, Regents of the University of California
10 * $PostgreSQL: pgsql/src/include/executor/executor.h,v 1.123 2005/12/03 05:51:03 tgl Exp $
12 *-------------------------------------------------------------------------
17 #include "executor/execdesc.h"
21 * ExecEvalExpr was formerly a function containing a switch statement;
22 * now it's just a macro invoking the function pointed to by an ExprState
23 * node. Beware of double evaluation of the ExprState argument!
25 #define ExecEvalExpr(expr, econtext, isNull, isDone) \
26 ((*(expr)->evalfunc) (expr, econtext, isNull, isDone))
30 * prototypes from functions in execAmi.c
32 extern void ExecReScan(PlanState *node, ExprContext *exprCtxt);
33 extern void ExecMarkPos(PlanState *node);
34 extern void ExecRestrPos(PlanState *node);
35 extern bool ExecSupportsMarkRestore(NodeTag plantype);
36 extern bool ExecSupportsBackwardScan(Plan *node);
37 extern bool ExecMayReturnRawTuples(PlanState *node);
40 * prototypes from functions in execGrouping.c
42 extern bool execTuplesMatch(TupleTableSlot *slot1,
43 TupleTableSlot *slot2,
45 AttrNumber *matchColIdx,
46 FmgrInfo *eqfunctions,
47 MemoryContext evalContext);
48 extern bool execTuplesUnequal(TupleTableSlot *slot1,
49 TupleTableSlot *slot2,
51 AttrNumber *matchColIdx,
52 FmgrInfo *eqfunctions,
53 MemoryContext evalContext);
54 extern FmgrInfo *execTuplesMatchPrepare(TupleDesc tupdesc,
56 AttrNumber *matchColIdx);
57 extern void execTuplesHashPrepare(TupleDesc tupdesc,
59 AttrNumber *matchColIdx,
60 FmgrInfo **eqfunctions,
61 FmgrInfo **hashfunctions);
62 extern TupleHashTable BuildTupleHashTable(int numCols, AttrNumber *keyColIdx,
63 FmgrInfo *eqfunctions,
64 FmgrInfo *hashfunctions,
65 int nbuckets, Size entrysize,
66 MemoryContext tablecxt,
67 MemoryContext tempcxt);
68 extern TupleHashEntry LookupTupleHashEntry(TupleHashTable hashtable,
73 * prototypes from functions in execJunk.c
75 extern JunkFilter *ExecInitJunkFilter(List *targetList, bool hasoid,
76 TupleTableSlot *slot);
77 extern JunkFilter *ExecInitJunkFilterConversion(List *targetList,
78 TupleDesc cleanTupType,
79 TupleTableSlot *slot);
80 extern bool ExecGetJunkAttribute(JunkFilter *junkfilter, TupleTableSlot *slot,
81 char *attrName, Datum *value, bool *isNull);
82 extern TupleTableSlot *ExecFilterJunk(JunkFilter *junkfilter,
83 TupleTableSlot *slot);
84 extern HeapTuple ExecRemoveJunk(JunkFilter *junkfilter, TupleTableSlot *slot);
88 * prototypes from functions in execMain.c
90 extern void ExecutorStart(QueryDesc *queryDesc, bool explainOnly);
91 extern TupleTableSlot *ExecutorRun(QueryDesc *queryDesc,
92 ScanDirection direction, long count);
93 extern void ExecutorEnd(QueryDesc *queryDesc);
94 extern void ExecutorRewind(QueryDesc *queryDesc);
95 extern void ExecCheckRTPerms(List *rangeTable);
96 extern void ExecEndPlan(PlanState *planstate, EState *estate);
97 extern bool ExecContextForcesOids(PlanState *planstate, bool *hasoids);
98 extern void ExecConstraints(ResultRelInfo *resultRelInfo,
99 TupleTableSlot *slot, EState *estate);
100 extern TupleTableSlot *EvalPlanQual(EState *estate, Index rti,
101 ItemPointer tid, TransactionId priorXmax);
104 * prototypes from functions in execProcnode.c
106 extern PlanState *ExecInitNode(Plan *node, EState *estate);
107 extern TupleTableSlot *ExecProcNode(PlanState *node);
108 extern Node *MultiExecProcNode(PlanState *node);
109 extern int ExecCountSlotsNode(Plan *node);
110 extern void ExecEndNode(PlanState *node);
113 * prototypes from functions in execQual.c
115 extern Datum GetAttributeByNum(HeapTupleHeader tuple, AttrNumber attrno,
117 extern Datum GetAttributeByName(HeapTupleHeader tuple, const char *attname,
119 extern void init_fcache(Oid foid, FuncExprState *fcache,
120 MemoryContext fcacheCxt);
121 extern Datum ExecMakeFunctionResult(FuncExprState *fcache,
122 ExprContext *econtext,
124 ExprDoneCond *isDone);
125 extern Tuplestorestate *ExecMakeTableFunctionResult(ExprState *funcexpr,
126 ExprContext *econtext,
127 TupleDesc expectedDesc,
128 TupleDesc *returnDesc);
129 extern Datum ExecEvalExprSwitchContext(ExprState *expression, ExprContext *econtext,
130 bool *isNull, ExprDoneCond *isDone);
131 extern ExprState *ExecInitExpr(Expr *node, PlanState *parent);
132 extern SubPlanState *ExecInitExprInitPlan(SubPlan *node, PlanState *parent);
133 extern ExprState *ExecPrepareExpr(Expr *node, EState *estate);
134 extern bool ExecQual(List *qual, ExprContext *econtext, bool resultForNull);
135 extern int ExecTargetListLength(List *targetlist);
136 extern int ExecCleanTargetListLength(List *targetlist);
137 extern TupleTableSlot *ExecProject(ProjectionInfo *projInfo,
138 ExprDoneCond *isDone);
141 * prototypes from functions in execScan.c
143 typedef TupleTableSlot *(*ExecScanAccessMtd) (ScanState *node);
145 extern TupleTableSlot *ExecScan(ScanState *node, ExecScanAccessMtd accessMtd);
146 extern void ExecAssignScanProjectionInfo(ScanState *node);
149 * prototypes from functions in execTuples.c
151 extern void ExecInitResultTupleSlot(EState *estate, PlanState *planstate);
152 extern void ExecInitScanTupleSlot(EState *estate, ScanState *scanstate);
153 extern TupleTableSlot *ExecInitExtraTupleSlot(EState *estate);
154 extern TupleTableSlot *ExecInitNullTupleSlot(EState *estate,
156 extern TupleDesc ExecTypeFromTL(List *targetList, bool hasoid);
157 extern TupleDesc ExecCleanTypeFromTL(List *targetList, bool hasoid);
158 extern TupleDesc ExecTypeFromExprList(List *exprList);
159 extern void UpdateChangedParamSet(PlanState *node, Bitmapset *newchg);
161 typedef struct TupOutputState
163 /* use "struct" here to allow forward reference */
164 struct AttInMetadata *metadata;
165 TupleTableSlot *slot;
169 extern TupOutputState *begin_tup_output_tupdesc(DestReceiver *dest,
171 extern void do_tup_output(TupOutputState *tstate, char **values);
172 extern void do_text_output_multiline(TupOutputState *tstate, char *text);
173 extern void end_tup_output(TupOutputState *tstate);
176 * Write a single line of text given as a C string.
178 * Should only be used with a single-TEXT-attribute tupdesc.
180 #define do_text_output_oneline(tstate, text_to_emit) \
183 values_[0] = (text_to_emit); \
184 do_tup_output(tstate, values_); \
189 * prototypes from functions in execUtils.c
191 extern EState *CreateExecutorState(void);
192 extern void FreeExecutorState(EState *estate);
193 extern ExprContext *CreateExprContext(EState *estate);
194 extern void FreeExprContext(ExprContext *econtext);
195 extern void ReScanExprContext(ExprContext *econtext);
197 #define ResetExprContext(econtext) \
198 MemoryContextReset((econtext)->ecxt_per_tuple_memory)
200 extern ExprContext *MakePerTupleExprContext(EState *estate);
202 /* Get an EState's per-output-tuple exprcontext, making it if first use */
203 #define GetPerTupleExprContext(estate) \
204 ((estate)->es_per_tuple_exprcontext ? \
205 (estate)->es_per_tuple_exprcontext : \
206 MakePerTupleExprContext(estate))
208 #define GetPerTupleMemoryContext(estate) \
209 (GetPerTupleExprContext(estate)->ecxt_per_tuple_memory)
211 /* Reset an EState's per-output-tuple exprcontext, if one's been created */
212 #define ResetPerTupleExprContext(estate) \
214 if ((estate)->es_per_tuple_exprcontext) \
215 ResetExprContext((estate)->es_per_tuple_exprcontext); \
218 extern void ExecAssignExprContext(EState *estate, PlanState *planstate);
219 extern void ExecAssignResultType(PlanState *planstate,
220 TupleDesc tupDesc, bool shouldFree);
221 extern void ExecAssignResultTypeFromTL(PlanState *planstate);
222 extern TupleDesc ExecGetResultType(PlanState *planstate);
223 extern ProjectionInfo *ExecBuildProjectionInfo(List *targetList,
224 ExprContext *econtext,
225 TupleTableSlot *slot);
226 extern void ExecAssignProjectionInfo(PlanState *planstate);
227 extern void ExecFreeExprContext(PlanState *planstate);
228 extern TupleDesc ExecGetScanType(ScanState *scanstate);
229 extern void ExecAssignScanType(ScanState *scanstate,
230 TupleDesc tupDesc, bool shouldFree);
231 extern void ExecAssignScanTypeFromOuterPlan(ScanState *scanstate);
233 extern bool ExecRelationIsTargetRelation(EState *estate, Index scanrelid);
235 extern Relation ExecOpenScanRelation(EState *estate, Index scanrelid);
236 extern void ExecCloseScanRelation(Relation scanrel);
238 extern void ExecOpenIndices(ResultRelInfo *resultRelInfo);
239 extern void ExecCloseIndices(ResultRelInfo *resultRelInfo);
240 extern void ExecInsertIndexTuples(TupleTableSlot *slot, ItemPointer tupleid,
241 EState *estate, bool is_vacuum);
243 extern void RegisterExprContextCallback(ExprContext *econtext,
244 ExprContextCallbackFunction function,
246 extern void UnregisterExprContextCallback(ExprContext *econtext,
247 ExprContextCallbackFunction function,
250 #endif /* EXECUTOR_H */