GBase 8c 查看系统表正在运行的查询语句

在GBase 8c数据库中,通过视图PG_STAT_ACTIVITY可以查看正在运行的查询语句。方法如下:

步骤1 设置参数track_activities为on。

SET track_activities = on;

当此参数为on时,数据库系统才会收集当前活动查询的运行信息。

步骤2 查看正在运行的查询语句。以查看正在运行的查询语句所连接的数据库名、执行查询的用户、查询状态及查询对应的PID为例:

SELECT datname, usename, state,pid FROM pg_stat_activity;

 datname  | usename | state | pid

----------+---------+--------+-----------------

postgres | Ruby | active | 140298793514752

postgres | Ruby | active | 140298718004992

postgres | Ruby | idle | 140298650908416

postgres | Ruby | idle | 140298625742592

postgres | gbase | active |  140298575406848

(5 rows)

如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。  如果仅需要查看非空闲的查询语句,则使用如下命令查看:

SELECT datname, usename, state FROM pg_stat_activity WHERE state !=  'idle';

步骤3  若需要取消运行时间过长的查询,通过PG_TERMINATE_BACKEND函数,根据线程ID 结束会话。

SELECT PG_TERMINATE_BACKEND(139834759993104);

显示类似如下信息,表示结束会话成功。

PG_TERMINATE_BACKEND

----------------------

t

(1 row)

显示类似如下信息,表示用户执行了结束当前会话的操作。

FATAL: terminating connection due to administrator command FATAL: terminating connection due to administrator command

gsql客户端使用PG_TERMINATE_BACKEND函数结束当前会话后台线程时,客户端不会退出而是自动重连。即还会返回“The connection to the server was lost. Attempting reset: Succeeded.”。显示如下:

FATAL: terminating connection due to administrator command FATAL: terminating connection due to administrator command

The connection to the server was lost. Attempting reset: Succeeded.

----结束

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值