受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

SPI_execute_plan

SPI_execute_plan — 执行由 SPI_prepare 准备好的语句

Synopsis

int SPI_execute_plan(SPIPlanPtr plan, Datum * values, const char * nulls,
                     bool read_only, long count)

描述

SPI_execute_plan 执行由 SPI_prepare 或其同类函数准备好的语句。read_onlycount 的含义与 SPI_execute 中相同。

参数

SPIPlanPtr plan

预备语句(由SPI_prepare返回)

Datum * values

一个实际参数值的数组。必须和语句的参数数量等长。

const char * nulls

一个描述哪些参数为空值的数组。必须和语句的参数数量等长。

如果nullsNULL, 那么SPI_execute_plan会假设没有参数 为空值。否则,如果对应的参数值为非空, nulls 数组的每一个项都应该是' ';如果对应参数值为空, nulls数组的项应为'n'(在后 面的情况中,对应的values项中的值没有 关系)。注意nulls不是一个文本字符串, 它只是一个数组:它不需要一个'\0'终止符。

bool read_only

true 表示只读执行

long count

要返回的最大行数,或者用 0 表示不限制

返回值

返回值和SPI_execute相同, 还有下列额外可能的错误(负值)结果:

SPI_ERROR_ARGUMENT

如果planNULL 或者非法,或者count小于 0

SPI_ERROR_PARAM

如果valuesNULL,但 plan在准备时带有参数

成功时,SPI_processedSPI_tuptable 的设置方式与 SPI_execute 相同。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。