SPI_cursor_open_with_args — 使用一个查询和参数建立一个游标
Portal SPI_cursor_open_with_args(const char *name, const char *command, intnargs, Oid *argtypes, Datum *values, const char *nulls, boolread_only, intcursorOptions)
SPI_cursor_open_with_args建立一个将 执行指定查询的游标(在内部是一个 portal)。大部分参数具有和 SPI_prepare_cursor 和SPI_cursor_open中相应参数相同的含 义。
对于一次性的查询执行,这个函数应该比 SPI_prepare_cursor加上其后的 SPI_cursor_open更好。如果相同的命令 要被用很多不同的参数执行,哪种方法更快就要取决于重做计划的 代价与定制计划带来的好处之间谁更有利。
传入的参数数据会被复制到该游标的 portal 中,因此即使该游标仍然存在, 也可以释放这些参数数据。
此函数现已废弃,推荐改用 SPI_cursor_parse_open, 它提供了等价的功能,并使用更现代的查询参数处理 API。
const char * nameportal 的名称,或为NULL以让系统选择名称
const char * command命令字符串
int nargs输入参数的数量($1、$2 等)
Oid * argtypes一个长度为nargs的数组, 包含参数的数据类型的OID
Datum * values一个长度为nargs的数组, 包含实际的参数值
const char * nulls一个长度为nargs的数组, 描述哪些参数为空值
如果nulls为NULL, 那么SPI_cursor_open_with_args会假设没有参数 为空值。否则,如果对应的参数值为非空, nulls 数组的每一个项都应该是' ';如果对应参数值为空, nulls数组的项应为'n'(在后 面的情况中,对应的values项中的值没有 关系)。注意nulls不是一个文本字符串, 它只是一个数组:它不需要一个'\0'终止符。
bool read_onlytrue 表示只读执行
int cursorOptions整数形式的游标选项位掩码,零会导致默认行为
指向包含该游标的 portal 的指针。注意这里没有错误返回约定, 任何错误都将通过elog报告。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。