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