46.4. 数据更改的可见性

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

  • 在执行 SQL 命令的过程中,该命令本身所做的任何数据更改都不可见。例如,在:
INSERT INTO a SELECT * FROM a;

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

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

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

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

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