Redrock Postgres 搜索 英文
版本: 10 / 11 / 12 / 13 / 14 / 15 / 16 / 17

DROP SUBSCRIPTION

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 扩展。

另请参阅

CREATE SUBSCRIPTIONALTER SUBSCRIPTION