DROP SUBSCRIPTION — 删除一个订阅
DROP SUBSCRIPTION [ IF EXISTS ] name
[ CASCADE | RESTRICT ]
DROP SUBSCRIPTION
删除数据库集群中的一个订阅。
只有超级用户才可以删除订阅。
如果订阅与复制槽相关联,就不能在事务块内部执行DROP SUBSCRIPTION
。(可以使用ALTER SUBSCRIPTION
取消关联复制槽。)
name
要删除的订阅的名称。
CASCADE
RESTRICT
这些关键词没有任何作用,因为订阅之上没有依赖关系。
在删除与远程主机(正常状态)上的复制槽相关联的订阅时,DROP SUBSCRIPTION
将连接到远程主机,并尝试删除该复制槽作为其操作的一部分。这是必要的,以便释放远程主机上为订阅分配的资源。如果由于远程主机不可访问、远程复制槽不能被删除、复制槽不存在或没有存在过等原因删除复制槽失败,则DROP SUBSCRIPTION
命令将失败。要在这种情况下继续,请执行ALTER SUBSCRIPTION ... SET (slot_name = NONE)
来解除复制槽与订阅的关联。之后,DROP SUBSCRIPTION
将不会在远程主机上尝试任何操作。注意,如果远程复制槽仍然存在,则应手动删除它;否则它将继续保留WAL,最终可能导致磁盘空间被填满。另见第 31.2.1 节。
如果订阅与复制槽相关联,那么不能在事务块内部执行DROP SUBSCRIPTION
。
删除一个订阅:
DROP SUBSCRIPTION mysub;
DROP SUBSCRIPTION
是一个PostgreSQL扩展。