以下规则规定了使用 SPI(或任何其他 C 函数)的函数中数据更改的可见性
在执行 SQL 命令时,由该命令进行的任何数据更新对于该命令本身来说都是不可见的。例如,在
INSERT INTO a SELECT * FROM a;
中,新增行对 SELECT
部分不可见。
由命令 C 进行的更改对于在 C 之后启动的所有命令都是可见的,无论它们是在 C 内部(在 C 正在执行时)还是在 C 完成之后启动的。
函数(普通函数或触发器)中一个 SQL 命令调用的 SPI 中执行的命令将根据传递给 SPI 的读/写标志遵循上面的规则中的一个。以只读模式执行的命令遵循第一条规则:它们无法看到调用命令的更改。以读写模式执行的命令遵循第二条规则:它们可以查看迄今为止所做的所有更改。
所有标准过程语言根据函数的易失性属性设置 SPI 读写模式。STABLE
和 IMMUTABLE
函数的命令以只读模式执行,而 VOLATILE
函数的命令以读写模式执行。虽然 C 函数的作者可以违反此约定,但这样做并不是一个好主意。
下一部分包含一个示例,说明了这些规则的应用。