Skip to content

47.5. 数据更改的可见性#

以下规则规定了使用 SPI(或任何其他 C 函数)的函数中数据更改的可见性

  • 在执行 SQL 命令期间,命令所做的任何数据更改对命令本身都是不可见的。例如,在

    INSERT INTO a SELECT * FROM a;
    

    插入的行对 SELECT 部分不可见。

  • 命令 C 所做的更改对在 C 之后启动的所有命令都是可见的,无论它们是在 C 内(在 C 执行期间)还是在 C 完成之后启动的。

  • 通过 SQL 命令(普通函数或触发器)调用的函数中通过 SPI 执行的命令将根据传递给 SPI 的读/写标志遵循上述规则之一。以只读模式执行的命令遵循第一条规则:它们看不到调用命令的更改。以读写模式执行的命令遵循第二条规则:它们可以看到到目前为止所做的所有更改。

  • 所有标准过程语言根据函数的易失性属性设置 SPI 读写模式。STABLEIMMUTABLE 函数的命令以只读模式执行,而 VOLATILE 函数的命令以读写模式执行。虽然 C 函数的作者能够违反此约定,但这不太可能是一个好主意。

下一部分包含一个示例,说明了这些规则的应用。