支持的版本: 当前 (17) / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 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

37.2. 数据更改的可见性 #

如果您在触发器函数中执行 SQL 命令,并且这些命令访问了触发器所针对的表,那么您需要了解数据可见性规则,因为这些规则决定了这些 SQL 命令是否会看到触发器触发的数据更改。简而言之:

  • 语句级触发器遵循简单的可见性规则:语句所做的任何更改对语句级的 BEFORE 触发器都不可见,而所有修改对语句级的 AFTER 触发器都可见。

  • 导致触发器触发的数据更改(插入、更新或删除)自然对在行级 BEFORE 触发器中执行的 SQL 命令不可见,因为它尚未发生。

  • 然而,在行级 BEFORE 触发器中执行的 SQL 命令看到同一外部命令中先前处理的行的数据更改效果。这需要谨慎,因为这些更改事件的顺序通常是不可预测的;影响多行的 SQL 命令可以以任何顺序访问这些行。

  • 类似地,行级 INSTEAD OF 触发器将看到同一外部命令中先前触发的 INSTEAD OF 触发器所做的数据更改的效果。

  • 当行级 AFTER 触发器被触发时,外部命令所做的所有数据更改都已完成,并且对调用的触发器函数可见。

如果您的触发器函数是用任何标准的过程语言编写的,那么只有当函数被声明为 VOLATILE 时,上述语句才适用。声明为 STABLEIMMUTABLE 的函数在任何情况下都不会看到调用命令所做的更改。

有关数据可见性规则的更多信息,请参阅第 45.5 节第 37.4 节中的示例包含了这些规则的演示。

提交更正

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