类型: | enum |
默认: | origin |
上下文: | superuser |
重新开始: | false |
值: | [origin, replica, local] |
为当前会话控制复制相关的触发器和规则的触发。需要超级用户权限才能设置这个变量,并且会导致丢弃任何之前缓存下来的查询计划。可能的值有origin
(默认)、replica
和local
。
这个设置的预期用途是由逻辑复制系统在应用所复制的更改时将它设置为replica
。其效果将是触发器和规则(没有对其默认配置做修改)在复制机上将不会被触发。更多信息请参考sql-altertable的子句ENABLE TRIGGER
以及ENABLE RULE
。
PostgreSQL在内部会把设置origin
和local
同样对待。第三方复制系统可能会把这两个值用于其内部目的,例如把local
用来标出一个不应复制其更改的会话。
因为外键被实现为触发器,将这个参数设置为replica
还会禁用所有的外键检查,如果使用不当可能会让数据处于一种不一致的状态。
建议 [EN]
Only gets changed for databases which are taking part in a replication chain. In that case, "origin" servers fire replication (and other) triggers, and "replica" do not. Part of the generic replication hooks which are used by Slony and Bucardo.