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