2024年9月26日: PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:开发版
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2 / 7.1

45.5. 数据更改的可见性 #

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

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

    INSERT INTO a SELECT * FROM a;
    

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

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

  • 通过 SPI 在 SQL 命令调用的函数(普通函数或触发器)内部执行的命令遵循上述规则之一,具体取决于传递给 SPI 的读/写标志。以只读模式执行的命令遵循第一条规则:它们无法查看调用命令的更改。以读写模式执行的命令遵循第二条规则:它们可以查看迄今为止所做的所有更改。

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

下一节包含一个说明这些规则应用的示例。

提交更正

如果您在文档中发现任何不正确的内容,与您对特定功能的体验不符,或者需要进一步澄清,请使用 此表单 报告文档问题。