受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

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

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。