Skip to content

DROP SUBSCRIPTION

DROP SUBSCRIPTION — 删除订阅

概要

DROP SUBSCRIPTION [ IF EXISTS ] name [ CASCADE | RESTRICT ]

描述

DROP SUBSCRIPTION从数据库集群中删除订阅。

要执行此命令,用户必须是订阅的所有者。

如果订阅与复制槽相关联,则无法在事务块内执行DROP SUBSCRIPTION。(您可以使用ALTER SUBSCRIPTION取消设置槽。)

参数

名称

要删除的订阅的名称。

CASCADE
RESTRICT

由于订阅没有任何依赖关系,因此这些关键字没有任何效果。

备注

当删除与远程主机上的复制槽关联的订阅(正常状态)时,DROP SUBSCRIPTION将连接到远程主机并尝试删除复制槽(以及任何剩余的表同步槽),作为其操作的一部分。这是必需的,以便释放为远程主机上的订阅分配的资源。如果此操作失败,可能是因为远程主机不可达,或者因为远程复制槽无法删除或不存在或从未存在,则DROP SUBSCRIPTION命令将失败。要在此情况下继续,请首先通过执行ALTER SUBSCRIPTION ... DISABLE禁用订阅,然后通过执行ALTER SUBSCRIPTION ... SET (slot_name = NONE)取消与复制槽的关联。之后,DROP SUBSCRIPTION将不再尝试在远程主机上执行任何操作。请注意,如果远程复制槽仍然存在,则应手动删除它(以及任何相关的表同步槽);否则,它/它们将继续保留 WAL,并最终可能导致磁盘空间不足。另请参见第 31.2.1 节

如果订阅与复制槽关联,则无法在事务块内执行DROP SUBSCRIPTION

示例

删除订阅

DROP SUBSCRIPTION mysub;

兼容性

DROP SUBSCRIPTION是PostgreSQL扩展。

另请参见

CREATE SUBSCRIPTIONALTER SUBSCRIPTION