DROP SUBSCRIPTION — 删除订阅
DROP SUBSCRIPTION [ IF EXISTS ] name
[ CASCADE | RESTRICT ]
DROP SUBSCRIPTION
从数据库集群中删除一个订阅。
要执行此命令,用户必须是订阅的所有者。
如果订阅与复制槽相关联,则 DROP SUBSCRIPTION
不能在事务块内执行。(您可以使用 ALTER SUBSCRIPTION
来取消设置槽。)
name
要删除的订阅的名称。
CASCADE
RESTRICT
这些关键字没有任何影响,因为订阅没有依赖关系。
当删除与远程主机上的复制槽(正常状态)关联的订阅时,DROP SUBSCRIPTION
将连接到远程主机,并尝试删除复制槽(以及任何剩余的表同步槽)作为其操作的一部分。这对于释放远程主机上为订阅分配的资源是必要的。如果此操作失败,原因可能是远程主机无法访问,或者无法删除远程复制槽,或者该槽不存在或从未存在,则 DROP SUBSCRIPTION
命令将失败。要在此情况下继续操作,首先执行 ALTER SUBSCRIPTION ... DISABLE
来禁用订阅,然后执行 ALTER SUBSCRIPTION ... SET (slot_name = NONE)
将其与复制槽解除关联。之后,DROP SUBSCRIPTION
将不再尝试对远程主机执行任何操作。请注意,如果远程复制槽仍然存在,则应手动删除它(以及任何相关的表同步槽);否则,它/它们将继续保留 WAL,并可能最终导致磁盘空间被填满。另请参阅 第 29.2.1 节。
如果订阅与复制槽关联,则 DROP SUBSCRIPTION
不能在事务块内执行。
删除一个订阅
DROP SUBSCRIPTION mysub;
DROP SUBSCRIPTION
是一个 PostgreSQL 扩展。
如果您在文档中发现任何不正确的内容,或者与您特定功能的使用体验不符,或者需要进一步澄清,请使用此表单来报告文档问题。