spi.h 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. /*-------------------------------------------------------------------------
  2. *
  3. * spi.h
  4. * Server Programming Interface public declarations
  5. *
  6. * Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group
  7. * Portions Copyright (c) 1994, Regents of the University of California
  8. *
  9. * src/include/executor/spi.h
  10. *
  11. *-------------------------------------------------------------------------
  12. */
  13. #ifndef SPI_H
  14. #define SPI_H
  15. #include "commands/trigger.h"
  16. #include "lib/ilist.h"
  17. #include "parser/parser.h"
  18. #include "utils/portal.h"
  19. typedef struct SPITupleTable
  20. {
  21. /* Public members */
  22. TupleDesc tupdesc; /* tuple descriptor */
  23. HeapTuple *vals; /* array of tuples */
  24. uint64 numvals; /* number of valid tuples */
  25. /* Private members, not intended for external callers */
  26. uint64 alloced; /* allocated length of vals array */
  27. MemoryContext tuptabcxt; /* memory context of result table */
  28. slist_node next; /* link for internal bookkeeping */
  29. SubTransactionId subid; /* subxact in which tuptable was created */
  30. } SPITupleTable;
  31. /* Optional arguments for SPI_prepare_extended */
  32. typedef struct SPIPrepareOptions
  33. {
  34. ParserSetupHook parserSetup;
  35. void *parserSetupArg;
  36. RawParseMode parseMode;
  37. int cursorOptions;
  38. } SPIPrepareOptions;
  39. /* Optional arguments for SPI_execute[_plan]_extended */
  40. typedef struct SPIExecuteOptions
  41. {
  42. ParamListInfo params;
  43. bool read_only;
  44. bool allow_nonatomic;
  45. bool must_return_tuples;
  46. uint64 tcount;
  47. DestReceiver *dest;
  48. ResourceOwner owner;
  49. } SPIExecuteOptions;
  50. /* Optional arguments for SPI_cursor_parse_open */
  51. typedef struct SPIParseOpenOptions
  52. {
  53. ParamListInfo params;
  54. int cursorOptions;
  55. bool read_only;
  56. } SPIParseOpenOptions;
  57. /* Plans are opaque structs for standard users of SPI */
  58. typedef struct _SPI_plan *SPIPlanPtr;
  59. #define SPI_ERROR_CONNECT (-1)
  60. #define SPI_ERROR_COPY (-2)
  61. #define SPI_ERROR_OPUNKNOWN (-3)
  62. #define SPI_ERROR_UNCONNECTED (-4)
  63. #define SPI_ERROR_CURSOR (-5) /* not used anymore */
  64. #define SPI_ERROR_ARGUMENT (-6)
  65. #define SPI_ERROR_PARAM (-7)
  66. #define SPI_ERROR_TRANSACTION (-8)
  67. #define SPI_ERROR_NOATTRIBUTE (-9)
  68. #define SPI_ERROR_NOOUTFUNC (-10)
  69. #define SPI_ERROR_TYPUNKNOWN (-11)
  70. #define SPI_ERROR_REL_DUPLICATE (-12)
  71. #define SPI_ERROR_REL_NOT_FOUND (-13)
  72. #define SPI_OK_CONNECT 1
  73. #define SPI_OK_FINISH 2
  74. #define SPI_OK_FETCH 3
  75. #define SPI_OK_UTILITY 4
  76. #define SPI_OK_SELECT 5
  77. #define SPI_OK_SELINTO 6
  78. #define SPI_OK_INSERT 7
  79. #define SPI_OK_DELETE 8
  80. #define SPI_OK_UPDATE 9
  81. #define SPI_OK_CURSOR 10
  82. #define SPI_OK_INSERT_RETURNING 11
  83. #define SPI_OK_DELETE_RETURNING 12
  84. #define SPI_OK_UPDATE_RETURNING 13
  85. #define SPI_OK_REWRITTEN 14
  86. #define SPI_OK_REL_REGISTER 15
  87. #define SPI_OK_REL_UNREGISTER 16
  88. #define SPI_OK_TD_REGISTER 17
  89. #define SPI_OK_MERGE 18
  90. #define SPI_OPT_NONATOMIC (1 << 0)
  91. /* These used to be functions, now just no-ops for backwards compatibility */
  92. #define SPI_push() ((void) 0)
  93. #define SPI_pop() ((void) 0)
  94. #define SPI_push_conditional() false
  95. #define SPI_pop_conditional(pushed) ((void) 0)
  96. #define SPI_restore_connection() ((void) 0)
  97. extern PGDLLIMPORT uint64 SPI_processed;
  98. extern PGDLLIMPORT SPITupleTable *SPI_tuptable;
  99. extern PGDLLIMPORT int SPI_result;
  100. extern int SPI_connect(void);
  101. extern int SPI_connect_ext(int options);
  102. extern int SPI_finish(void);
  103. extern int SPI_execute(const char *src, bool read_only, long tcount);
  104. extern int SPI_execute_extended(const char *src,
  105. const SPIExecuteOptions *options);
  106. extern int SPI_execute_plan(SPIPlanPtr plan, Datum *Values, const char *Nulls,
  107. bool read_only, long tcount);
  108. extern int SPI_execute_plan_extended(SPIPlanPtr plan,
  109. const SPIExecuteOptions *options);
  110. extern int SPI_execute_plan_with_paramlist(SPIPlanPtr plan,
  111. ParamListInfo params,
  112. bool read_only, long tcount);
  113. extern int SPI_exec(const char *src, long tcount);
  114. extern int SPI_execp(SPIPlanPtr plan, Datum *Values, const char *Nulls,
  115. long tcount);
  116. extern int SPI_execute_snapshot(SPIPlanPtr plan,
  117. Datum *Values, const char *Nulls,
  118. Snapshot snapshot,
  119. Snapshot crosscheck_snapshot,
  120. bool read_only, bool fire_triggers, long tcount);
  121. extern int SPI_execute_with_args(const char *src,
  122. int nargs, Oid *argtypes,
  123. Datum *Values, const char *Nulls,
  124. bool read_only, long tcount);
  125. extern SPIPlanPtr SPI_prepare(const char *src, int nargs, Oid *argtypes);
  126. extern SPIPlanPtr SPI_prepare_cursor(const char *src, int nargs, Oid *argtypes,
  127. int cursorOptions);
  128. extern SPIPlanPtr SPI_prepare_extended(const char *src,
  129. const SPIPrepareOptions *options);
  130. extern SPIPlanPtr SPI_prepare_params(const char *src,
  131. ParserSetupHook parserSetup,
  132. void *parserSetupArg,
  133. int cursorOptions);
  134. extern int SPI_keepplan(SPIPlanPtr plan);
  135. extern SPIPlanPtr SPI_saveplan(SPIPlanPtr plan);
  136. extern int SPI_freeplan(SPIPlanPtr plan);
  137. extern Oid SPI_getargtypeid(SPIPlanPtr plan, int argIndex);
  138. extern int SPI_getargcount(SPIPlanPtr plan);
  139. extern bool SPI_is_cursor_plan(SPIPlanPtr plan);
  140. extern bool SPI_plan_is_valid(SPIPlanPtr plan);
  141. extern const char *SPI_result_code_string(int code);
  142. extern List *SPI_plan_get_plan_sources(SPIPlanPtr plan);
  143. extern CachedPlan *SPI_plan_get_cached_plan(SPIPlanPtr plan);
  144. extern HeapTuple SPI_copytuple(HeapTuple tuple);
  145. extern HeapTupleHeader SPI_returntuple(HeapTuple tuple, TupleDesc tupdesc);
  146. extern HeapTuple SPI_modifytuple(Relation rel, HeapTuple tuple, int natts,
  147. int *attnum, Datum *Values, const char *Nulls);
  148. extern int SPI_fnumber(TupleDesc tupdesc, const char *fname);
  149. extern char *SPI_fname(TupleDesc tupdesc, int fnumber);
  150. extern char *SPI_getvalue(HeapTuple tuple, TupleDesc tupdesc, int fnumber);
  151. extern Datum SPI_getbinval(HeapTuple tuple, TupleDesc tupdesc, int fnumber, bool *isnull);
  152. extern char *SPI_gettype(TupleDesc tupdesc, int fnumber);
  153. extern Oid SPI_gettypeid(TupleDesc tupdesc, int fnumber);
  154. extern char *SPI_getrelname(Relation rel);
  155. extern char *SPI_getnspname(Relation rel);
  156. extern void *SPI_palloc(Size size);
  157. extern void *SPI_repalloc(void *pointer, Size size);
  158. extern void SPI_pfree(void *pointer);
  159. extern Datum SPI_datumTransfer(Datum value, bool typByVal, int typLen);
  160. extern void SPI_freetuple(HeapTuple pointer);
  161. extern void SPI_freetuptable(SPITupleTable *tuptable);
  162. extern Portal SPI_cursor_open(const char *name, SPIPlanPtr plan,
  163. Datum *Values, const char *Nulls, bool read_only);
  164. extern Portal SPI_cursor_open_with_args(const char *name,
  165. const char *src,
  166. int nargs, Oid *argtypes,
  167. Datum *Values, const char *Nulls,
  168. bool read_only, int cursorOptions);
  169. extern Portal SPI_cursor_open_with_paramlist(const char *name, SPIPlanPtr plan,
  170. ParamListInfo params, bool read_only);
  171. extern Portal SPI_cursor_parse_open(const char *name,
  172. const char *src,
  173. const SPIParseOpenOptions *options);
  174. extern Portal SPI_cursor_find(const char *name);
  175. extern void SPI_cursor_fetch(Portal portal, bool forward, long count);
  176. extern void SPI_cursor_move(Portal portal, bool forward, long count);
  177. extern void SPI_scroll_cursor_fetch(Portal, FetchDirection direction, long count);
  178. extern void SPI_scroll_cursor_move(Portal, FetchDirection direction, long count);
  179. extern void SPI_cursor_close(Portal portal);
  180. extern int SPI_register_relation(EphemeralNamedRelation enr);
  181. extern int SPI_unregister_relation(const char *name);
  182. extern int SPI_register_trigger_data(TriggerData *tdata);
  183. extern void SPI_start_transaction(void);
  184. extern void SPI_commit(void);
  185. extern void SPI_commit_and_chain(void);
  186. extern void SPI_rollback(void);
  187. extern void SPI_rollback_and_chain(void);
  188. extern void AtEOXact_SPI(bool isCommit);
  189. extern void AtEOSubXact_SPI(bool isCommit, SubTransactionId mySubid);
  190. extern bool SPI_inside_nonatomic_context(void);
  191. #endif /* SPI_H */