PostgreSQL服务器会为收到的每条命令返回一个命令状态字符串,例如INSERT 149592 1。在没有规则参与时,这很简单;但当查询被规则重写时会发生什么呢?
规则对命令状态的影响如下:
如果该查询没有无条件的INSTEAD规则,那么原始给出的查询就会照常执行,并返回它自身的命令状态。(但请注意,如果存在任何带条件的INSTEAD规则,那么这些规则条件的取反会被加到原始查询上。这可能会减少它处理的行数,从而影响报告的状态。)
如果该查询存在任意无条件的INSTEAD规则,那么原始查询将完全不会执行。在这种情况下,服务器会返回由INSTEAD规则(带条件或不带条件)插入的、最后一条且与原始查询具有相同命令类型(INSERT、UPDATE或DELETE)的查询的命令状态。如果没有任何规则添加出满足这些条件的查询,那么返回的命令状态会显示原始查询类型,并且把行计数和 OID 字段都置零。
在第二种情况下,程序员可以通过为所需的INSTEAD规则指定一个在活动规则中按字母顺序排在最后的规则名,来确保由它设置命令状态,因为它会最后被应用。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。