# 39.2.数据更改的可见性

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

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

  • 导致触发的数据更改(插入、更新或删除)是自然发生的对行级别执行的SQL命令可见之前触发,因为它还没有发生。

  • 但是,SQL命令是在行级别执行的之前触发请参见之前在同一外部命令中处理的行的数据更改的效果。这需要谨慎,因为这些变化事件的顺序通常是不可预测的;影响多行的SQL命令可以按任意顺序访问这些行。

  • 类似地,行级别而不是触发器将看到以前触发的数据更改的影响而不是在同一外部命令中触发。

  • 当一行水平之后触发触发器时,外部命令所做的所有数据更改都已完成,并且对调用的触发器函数可见。

    如果触发器函数是用任何标准过程语言编写的,则上述语句仅在声明该函数时适用不稳定的.声明的函数稳定的不变的在任何情况下都不会看到调用命令所做的更改。

    有关数据可见性规则的更多信息,请参见第47.5节.例如第39.4节包含这些规则的演示。