Skip to content

39.2. 数据更改的可见性#

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

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

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

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

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

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

如果您的触发器函数是用任何标准过程语言编写的,则以上语句仅在函数声明为VOLATILE时适用。在任何情况下,声明为STABLEIMMUTABLE的函数都看不到调用命令所做的更改。

可以在第 47.5 节中找到有关数据可见性规则的更多信息。第 39.4 节中的示例演示了这些规则。