目录
SPI_prepare
准备的语句所需的参数数量SPI_prepare
准备的语句的参数的数据类型 OIDSPI_prepare
准备的语句可以与 SPI_cursor_open
一起使用,则返回 true
SPI_prepare
准备的语句SPI_prepare
准备的语句SPI_prepare
准备的语句SPI_prepare
创建的语句设置一个游标SPI_execute
或类似函数创建的行集服务器编程接口 (SPI) 为用户自定义的C函数编写者提供了在其函数或过程内部运行SQL命令的能力。SPI是一组接口函数,用于简化对解析器、规划器和执行器的访问。SPI还进行一些内存管理。
可用的过程语言提供了从函数执行 SQL 命令的各种方法。这些工具大多基于 SPI,因此本文档也可能对这些语言的用户有用。
请注意,如果通过 SPI 调用的命令失败,则控制权不会返回到您的 C 函数。相反,执行您的 C 函数的事务或子事务将被回滚。(考虑到 SPI 函数大多有文档记录的错误返回约定,这可能看起来令人惊讶。但是,这些约定仅适用于 SPI 函数本身检测到的错误。)可以通过围绕可能失败的 SPI 调用建立自己的子事务来在错误后恢复控制权。
SPI函数在成功时返回一个非负结果(通过返回的整数值或全局变量 SPI_result
,如下所述)。如果出错,将返回一个负结果或 NULL
。
使用 SPI 的源代码文件必须包含头文件 executor/spi.h
。
如果您在文档中发现任何不正确、与您使用特定功能的经验不符或需要进一步澄清的地方,请使用此表单报告文档问题。