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

postgresql学习笔记(三)连接管理,第1张

概述使用以下三个SQL语句来取消正在运行的查询并终止连接 (1)查出活动连接列表及其进程ID select * from pg_stat_activity; (2)取消连接上的活动查询 select pg_cancel_backend(procid); 该 *** 作不会终止连接本身 (3)终止该连接 select pg_terminate_backend(procid); 如果你未停止某个连接上正在执行的语

使用以下三个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';
总结

以上是内存溢出为你收集整理的postgresql学习笔记(三)连接管理全部内容,希望文章能够帮你解决postgresql学习笔记(三)连接管理所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1173253.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存