如果在触发器函数中执行 SQL 命令,并且这些命令访问触发器所属的表,则需要了解数据可见性规则,因为这些规则决定了这些 SQL 命令是否会看到触发器触发的那些数据更改。简而言之
语句级触发器遵循简单的可见性规则:语句级 BEFORE
触发器看不到语句所做的任何更改,而语句级 AFTER
触发器可以看到所有修改。
触发器触发的导致数据更改(插入、更新或删除)自然不可见于在行级 BEFORE
触发器中执行的 SQL 命令,因为更改尚未发生。
但是,在行级 BEFORE
触发器中执行的 SQL 命令将看到相同外部命令中先前处理的行的数据更改的影响。这需要谨慎,因为这些更改事件的顺序通常是不可预测的;影响多行的 SQL 命令可以以任何顺序访问这些行。
类似地,行级 INSTEAD OF
触发器将看到相同外部命令中先前触发的 INSTEAD OF
触发器所做的数据更改的影响。
当触发行级 AFTER
触发器时,外部命令所做的所有数据更改都已完成,并且对调用的触发器函数可见。
如果您的触发器函数是用任何标准过程语言编写的,则上述语句仅在函数声明为 VOLATILE
时才适用。声明为 STABLE
或 IMMUTABLE
的函数在任何情况下都看不到调用命令所做的更改。
如果您在文档中看到任何不正确的内容,与您对特定功能的体验不符,或者需要进一步澄清,请使用此表单 报告文档问题。