受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

37.2. 数据更改的可见性 #

如果你在触发器函数中执行 SQL 命令,而这些命令又访问该触发器所属的表,就需要了解数据可见性规则,因为这些规则决定了这些 SQL 命令是否能看到引发触发器的数据更改。简而言之:

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

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

  • 然而,在行级 BEFORE 触发器中执行的 SQL 命令 看到同一外层命令中先前已处理各行上的数据更改结果。这里必须小心,因为这些更改事件的顺序通常不可预测;一条影响多行的 SQL 命令可能按任意顺序访问这些行。

  • 类似地,行级 INSTEAD OF 触发器会看到同一外层命令中此前触发的 INSTEAD OF 触发器所造成的数据更改结果。

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

如果你的触发器函数是用任何一种标准过程语言编写的,那么只有在该函数被声明为 VOLATILE 时,上述说法才成立。被声明为 STABLEIMMUTABLE 的函数在任何情况下都看不到调用命令所做的更改。

有关数据可见性规则的更多信息可见 Section 45.5Section 37.4 中的示例展示了这些规则。

提交更正

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