• Kevin Grittner's avatar
    Add infrastructure to support EphemeralNamedRelation references. · 18ce3a4a
    Kevin Grittner authored
    A QueryEnvironment concept is added, which allows new types of
    objects to be passed into queries from parsing on through
    execution.  At this point, the only thing implemented is a
    collection of EphemeralNamedRelation objects -- relations which
    can be referenced by name in queries, but do not exist in the
    catalogs.  The only type of ENR implemented is NamedTuplestore, but
    provision is made to add more types fairly easily.
    
    An ENR can carry its own TupleDesc or reference a relation in the
    catalogs by relid.
    
    Although these features can be used without SPI, convenience
    functions are added to SPI so that ENRs can easily be used by code
    run through SPI.
    
    The initial use of all this is going to be transition tables in
    AFTER triggers, but that will be added to each PL as a separate
    commit.
    
    An incidental effect of this patch is to produce a more informative
    error message if an attempt is made to modify the contents of a CTE
    from a referencing DML statement.  No tests previously covered that
    possibility, so one is added.
    
    Kevin Grittner and Thomas Munro
    Reviewed by Heikki Linnakangas, David Fetter, and Thomas Munro
    with valuable comments and suggestions from many others
    18ce3a4a
execdesc.h 2.29 KB
/*-------------------------------------------------------------------------
 *
 * execdesc.h
 *	  plan and query descriptor accessor macros used by the executor
 *	  and related modules.
 *
 *
 * Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group
 * Portions Copyright (c) 1994, Regents of the University of California
 *
 * src/include/executor/execdesc.h
 *
 *-------------------------------------------------------------------------
 */
#ifndef EXECDESC_H
#define EXECDESC_H

#include "nodes/execnodes.h"
#include "tcop/dest.h"


/* ----------------
 *		query descriptor:
 *
 *	a QueryDesc encapsulates everything that the executor
 *	needs to execute the query.
 *
 *	For the convenience of SQL-language functions, we also support QueryDescs
 *	containing utility statements; these must not be passed to the executor
 *	however.
 * ---------------------
 */
typedef struct QueryDesc
{
	/* These fields are provided by CreateQueryDesc */
	CmdType		operation;		/* CMD_SELECT, CMD_UPDATE, etc. */
	PlannedStmt *plannedstmt;	/* planner's output (could be utility, too) */
	const char *sourceText;		/* source text of the query */
	Snapshot	snapshot;		/* snapshot to use for query */
	Snapshot	crosscheck_snapshot;	/* crosscheck for RI update/delete */
	DestReceiver *dest;			/* the destination for tuple output */
	ParamListInfo params;		/* param values being passed in */
	QueryEnvironment *queryEnv; /* query environment passed in */
	int			instrument_options;		/* OR of InstrumentOption flags */

	/* These fields are set by ExecutorStart */
	TupleDesc	tupDesc;		/* descriptor for result tuples */
	EState	   *estate;			/* executor's query-wide state */
	PlanState  *planstate;		/* tree of per-plan-node state */

	/* This field is set by ExecutorRun */
	bool		already_executed;		/* true if previously executed */

	/* This is always set NULL by the core system, but plugins can change it */
	struct Instrumentation *totaltime;	/* total time spent in ExecutorRun */
} QueryDesc;

/* in pquery.c */
extern QueryDesc *CreateQueryDesc(PlannedStmt *plannedstmt,
				const char *sourceText,
				Snapshot snapshot,
				Snapshot crosscheck_snapshot,
				DestReceiver *dest,
				ParamListInfo params,
				QueryEnvironment *queryEnv,
				int instrument_options);

extern void FreeQueryDesc(QueryDesc *qdesc);

#endif   /* EXECDESC_H  */