如果在触发器函数中执行 SQL 命令,并且这些命令访问触发器所属的表,那么您需要注意数据可视性规则,因为它们决定了这些 SQL 命令是否会看到触发器触发的数据更改。简而言之:
语句级触发器遵循简单的可见性规则:语句所做的任何更改都对语句级的 BEFORE 触发器不可见,而所有修改对语句级的 AFTER 触发器都是可见的。
导致触发器触发的数据更改(插入、更新或删除)自然对行级 BEFORE 触发器中执行的 SQL 命令是 不可见 的,因为它们尚未发生。
然而,行级 BEFORE 触发器中执行的 SQL 命令 将 看到同一外部命令中先前处理过的行的对数据更改的影响。这需要谨慎,因为这些更改事件的顺序通常是不可预测的;影响多行的 SQL 命令可以按任何顺序访问这些行。
同样,行级 INSTEAD OF 触发器将看到同一外部命令中先前触发 INSTEAD OF 触发器的影响。
当行级 AFTER 触发器被触发时,外部命令所做的所有数据更改都已完成,并且对调用的触发器函数是可见的。
如果您的触发器函数是用任何标准过程语言编写的,那么上述陈述仅在函数声明为 VOLATILE 时适用。声明为 STABLE 或 IMMUTABLE 的函数在任何情况下都不会看到调用命令所做的更改。