天天看点

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

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

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

<code>select</code> <code>* </code><code>from</code> <code>pg_stat_activity;</code>

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

<code>select</code> <code>pg_cancel_backend(procid);</code>

该操作不会终止连接本身

(3)终止该连接

<code>select</code> <code>pg_terminate_backend(procid);</code>

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

终止连接的方式。

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

<code>   </code><code>select</code> <code>pg_terminate_backend(pid) </code><code>from</code> <code>pg_stat_activity </code><code>where</code> <code>username=</code><code>'some_role'</code><code>;</code>

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

<code>  </code><code>select</code> <code>pg_terminate_backend(procpid) </code><code>from</code> <code>pg_stat_activity </code><code>where</code> <code>username=</code><code>'some_role'</code><code>;</code>

本文转自 corasql 51CTO博客,原文链接:http://blog.51cto.com/corasql/1911927,如需转载请自行联系原作者