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

📄 dest.h

📁 PostgreSQL 8.2中增加了很多企业用户所需要的功能和性能上的提高,其开发团队说,该版本将加速更多企业向该数据库移植.核心开发成员之一Bruce Momjian表示,在新版PostgreSQL
💻 H
字号:
/*------------------------------------------------------------------------- * * dest.h *	  support for communication destinations * * Whenever the backend executes a query that returns tuples, the results * have to go someplace.  For example: * *	  - stdout is the destination only when we are running a *		standalone backend (no postmaster) and are returning results *		back to an interactive user. * *	  - a remote process is the destination when we are *		running a backend with a frontend and the frontend executes *		PQexec() or PQfn().  In this case, the results are sent *		to the frontend via the functions in backend/libpq. * *	  - DestNone is the destination when the system executes *		a query internally.  The results are discarded. * * dest.c defines three functions that implement destination management: * * BeginCommand: initialize the destination at start of command. * CreateDestReceiver: return a pointer to a struct of destination-specific * receiver functions. * EndCommand: clean up the destination at end of command. * * BeginCommand/EndCommand are executed once per received SQL query. * * CreateDestReceiver returns a receiver object appropriate to the specified * destination.  The executor, as well as utility statements that can return * tuples, are passed the resulting DestReceiver* pointer.	Each executor run * or utility execution calls the receiver's rStartup method, then the * receiveSlot method (zero or more times), then the rShutdown method. * The same receiver object may be re-used multiple times; eventually it is * destroyed by calling its rDestroy method. * * The DestReceiver object returned by CreateDestReceiver may be a statically * allocated object (for destination types that require no local state), * in which case rDestroy is a no-op.  Alternatively it can be a palloc'd * object that has DestReceiver as its first field and contains additional * fields (see printtup.c for an example).	These additional fields are then * accessible to the DestReceiver functions by casting the DestReceiver* * pointer passed to them.	The palloc'd object is pfree'd by the rDestroy * method.	Note that the caller of CreateDestReceiver should take care to * do so in a memory context that is long-lived enough for the receiver * object not to disappear while still needed. * * Special provision: None_Receiver is a permanently available receiver * object for the DestNone destination.  This avoids useless creation/destroy * calls in portal and cursor manipulations. * * * Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * $PostgreSQL: pgsql/src/include/tcop/dest.h,v 1.52 2006/08/30 23:34:22 tgl Exp $ * *------------------------------------------------------------------------- */#ifndef DEST_H#define DEST_H#include "executor/tuptable.h"/* buffer size to use for command completion tags */#define COMPLETION_TAG_BUFSIZE	64/* ---------------- *		CommandDest is a simplistic means of identifying the desired *		destination.  Someday this will probably need to be improved. * * Note: only the values DestNone, DestDebug, DestRemote are legal for the * global variable whereToSendOutput.	The other values may be used * as the destination for individual commands. * ---------------- */typedef enum{	DestNone,					/* results are discarded */	DestDebug,					/* results go to debugging output */	DestRemote,					/* results sent to frontend process */	DestRemoteExecute,			/* sent to frontend, in Execute command */	DestSPI,					/* results sent to SPI manager */	DestTuplestore,				/* results sent to Tuplestore */	DestIntoRel,				/* results sent to relation (SELECT INTO) */	DestCopyOut					/* results sent to COPY TO code */} CommandDest;/* ---------------- *		DestReceiver is a base type for destination-specific local state. *		In the simplest cases, there is no state info, just the function *		pointers that the executor must call. * * Note: the receiveSlot routine must be passed a slot containing a TupleDesc * identical to the one given to the rStartup routine. * ---------------- */typedef struct _DestReceiver DestReceiver;struct _DestReceiver{	/* Called for each tuple to be output: */	void		(*receiveSlot) (TupleTableSlot *slot,											DestReceiver *self);	/* Per-executor-run initialization and shutdown: */	void		(*rStartup) (DestReceiver *self,										 int operation,										 TupleDesc typeinfo);	void		(*rShutdown) (DestReceiver *self);	/* Destroy the receiver object itself (if dynamically allocated) */	void		(*rDestroy) (DestReceiver *self);	/* CommandDest code for this receiver */	CommandDest mydest;	/* Private fields might appear beyond this point... */};extern DestReceiver *None_Receiver;		/* permanent receiver for DestNone *//* This is a forward reference to utils/portal.h */typedef struct PortalData *Portal;/* The primary destination management functions */extern void BeginCommand(const char *commandTag, CommandDest dest);extern DestReceiver *CreateDestReceiver(CommandDest dest, Portal portal);extern void EndCommand(const char *commandTag, CommandDest dest);/* Additional functions that go with destination management, more or less. */extern void NullCommand(CommandDest dest);extern void ReadyForQuery(CommandDest dest);#endif   /* DEST_H */

⌨️ 快捷键说明

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