postgresql学习笔记连接管理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了postgresql学习笔记连接管理相关的知识,希望对你有一定的参考价值。

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

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

select * from pg_stat_activity;

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

select pg_cancel_backend(procid);

该操作不会终止连接本身

(3)终止该连接

select pg_terminate_backend(procid);

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

终止连接的方式。


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

   select pg_terminate_backend(pid) from pg_stat_activity where username=‘some_role‘;

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

  select pg_terminate_backend(procpid) from pg_stat_activity where username=‘some_role‘;


本文出自 “corasql” 博客,请务必保留此出处http://corasql.blog.51cto.com/5908329/1911927

以上是关于postgresql学习笔记连接管理的主要内容,如果未能解决你的问题,请参考以下文章

Postgresql 学习笔记

PostgreSQL远程代码执行漏洞(CVE-2018-1058)学习笔记

学习笔记:python3,代码片段(2017)

Python 3学习笔记

[原创]java WEB学习笔记61:Struts2学习之路--通用标签 property,uri,param,set,push,if-else,itertor,sort,date,a标签等(代码片段

项目管理学习笔记之六.领导力