# 47.5.数据更改的可见性

以下规则控制使用SPI(或任何其他C函数)的函数中数据更改的可见性:

  • 在执行SQL命令期间,命令所做的任何数据更改对命令本身都是不可见的。例如,在:

    INSERT INTO a SELECT * FROM a;
    

    插入的行对用户不可见选择部分

  • 命令C所做的更改对在C之后启动的所有命令都可见,无论它们是在C内部启动(在C执行期间)还是在C完成后启动。

  • 在SQL命令(普通函数或触发器)调用的函数中,通过SPI执行的命令遵循上述规则之一,具体取决于传递给SPI的读/写标志。在只读模式下执行的命令遵循第一条规则:它们看不到调用命令的更改。在读写模式下执行的命令遵循第二条规则:它们可以看到迄今为止所做的所有更改。

  • 所有标准过程语言都会根据函数的volatility属性设置SPI读写模式。命令稳定的不变的函数在只读模式下完成,而不稳定的函数在读写模式下完成。虽然C函数的作者能够违反这个约定,但这样做不太可能是个好主意。

    下一节包含一个示例,说明这些规则的应用。