以下规则控制使用 SPI(或任何其他 C 函数)的函数中数据更改的可见性
在 SQL 命令执行期间,命令所做的任何数据更改对命令本身都是不可见的。 例如,在
INSERT INTO a SELECT * FROM a;
插入的行对于 SELECT
部分是不可见的。
命令 C 所做的更改对于在 C 之后启动的所有命令都是可见的,无论它们是在 C 内部(在 C 执行期间)启动还是在 C 完成之后启动。
通过 SPI 在 SQL 命令(普通函数或触发器)调用的函数内执行的命令,根据传递给 SPI 的读取/写入标志遵循上述规则之一。 以只读模式执行的命令遵循第一条规则:它们看不到调用命令的更改。 以读写模式执行的命令遵循第二条规则:它们可以看到到目前为止所做的所有更改。
所有标准的过程语言都根据函数的易失性属性设置 SPI 读写模式。 STABLE
和 IMMUTABLE
函数的命令以只读模式完成,而 VOLATILE
函数的命令以读写模式完成。虽然 C 函数的作者能够违反此约定,但这不太可能是一个好主意。
下一节包含一个示例,说明这些规则的应用。
如果您发现文档中有任何不正确、与您对特定功能的体验不符或需要进一步澄清的地方,请使用此表单报告文档问题。