Redrock Postgres 搜索 英文
版本: 9.3 / 9.4 / 9.5 / 9.6 / 10 / 11 / 12 / 13 / 14 / 15 / 16 / 17 / 18

UNLISTEN

UNLISTEN — 停止监听通知

Synopsis

UNLISTEN { channel | * }

描述

UNLISTEN用于移除现有的 NOTIFY事件注册。 UNLISTEN会取消当前 PostgreSQL会话作为名为channel的通知通道监听者的任何现有注册。 特殊通配符*会取消当前会话的所有监听注册。

NOTIFY中对LISTENNOTIFY的使用有更详细的讨论。

参数

channel

通知通道的名称(任意标识符)。

*

该会话当前的所有监听注册都会被清除。

注解

对自己并未监听的通道执行UNLISTEN,不会出现警告或错误。

每个会话结束时,都会自动执行UNLISTEN *

执行过UNLISTEN的事务不能为两阶段提交做准备。

示例

建立一个监听注册:

LISTEN virtual;
NOTIFY virtual;
Asynchronous notification "virtual" received from server process with PID 8448.

执行UNLISTEN之后,后续的NOTIFY 消息将被忽略:

UNLISTEN virtual;
NOTIFY virtual;
-- no NOTIFY event is received

兼容性

SQL 标准中没有UNLISTEN语句。

另见

LISTEN, NOTIFY