问题报告 纠错本页面

UNLISTEN

名称

UNLISTEN -- 停止监听通知信息

大纲

UNLISTEN { channel | * }

描述

UNLISTEN用于删除一个现有的已注册NOTIFY事件。 UNLISTEN取消当前PostgreSQL 会话中所有对通知通道名为channel的监听。 特殊的条件通配符*取消对当前会话的所有监听。

NOTIFY包含一些对LISTENNOTIFY的更广泛的讨论。

参数

channel

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

*

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

注意

即使取消一个你没有监听的事件,后端也不会警告或报错。

每个会话在退出时都会自动执行UNLISTEN *

一个已经执行了UNLISTEN的事务不能为二阶段提交做准备。

例子

注册一个:

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

一旦执行了UNLISTEN,以后的NOTIFY信息都将被忽略:

UNLISTEN virtual;
NOTIFY virtual;
-- 收不到 NOTIFY 事件

兼容性

SQL 标准里没有UNLISTEN命令。

又见

LISTEN, NOTIFY