加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

postgresql学习笔记(三)连接管理

发布时间:2020-12-13 16:56:41 所属栏目:百科 来源:网络整理
导读:使用以下三个SQL语句来取消正在运行的查询并终止连接 (1)查出活动连接列表及其进程ID select*frompg_stat_activity; (2)取消连接上的活动查询 selectpg_cancel_backend(procid); 该操作不会终止连接本身 (3)终止该连接 selectpg_terminate_backend(proci

使用以下三个SQL语句来取消正在运行的查询并终止连接

(1)查出活动连接列表及其进程ID

select*frompg_stat_activity;

(2)取消连接上的活动查询

selectpg_cancel_backend(procid);

该操作不会终止连接本身

(3)终止该连接

selectpg_terminate_backend(procid);

如果你未停止某个连接上正在执行的语句就直接终止该连接,那么这些语句此时也会被停止掉。在上述步骤2执行完毕后,客户端应用的挂起状态被解除,即客户端可以重新执行语句,有些着急的用户会在此时再次执行刚刚被终止掉的语句,这又会导致系统陷入之前的状态。为了避免此种情况的发生,可以采用直接

终止连接的方式。


如果你希望一次性终止某个用户的所有连接,那么在9.2版及之后的版本上可以执行以下语句:

selectpg_terminate_backend(pid)frompg_stat_activitywhereusername='some_role';

在9.2版之前的版本上可以执行以下语句:

selectpg_terminate_backend(procpid)frompg_stat_activitywhereusername='some_role';

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读