云数据库 GAUSSDB-查看系统表:查看和停止正在运行的查询语句
查看和停止正在运行的查询语句
通过视图PG_STAT_ACTIVITY可以查看正在运行的查询语句。方法如下:
- 设置参数track_activities为on。
1
SET track_activities = on;
当此参数为on时,数据库系统才会收集当前活动查询的运行信息。
- 查看正在运行的查询语句。以查看正在运行的查询语句所连接的数据库名、执行查询的用户、查询状态及查询对应的PID为例:
1
SELECT datname, usename, state,pid FROM pg_stat_activity;
1 2 3 4 5 6 7 8
datname | usename | state | pid ----------+---------+--------+----------------- postgres | Ruby | active | 140298793514752 postgres | Ruby | active | 140298718004992 postgres | Ruby | idle | 140298650908416 postgres | Ruby | idle | 140298625742592 postgres | omm | active | 140298575406848 (5 rows)
如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。
如果仅需要查看非空闲的查询语句,则使用如下命令查看:
1
SELECT datname, usename, state pid FROM pg_stat_activity WHERE state != 'idle';
- 若需要取消运行时间过长的查询,通过PG_TERMINATE_BACKEND函数,根据线程ID结束会话。
1
SELECT PG_TERMINATE_BACKEND(139834759993104);
显示类似如下信息,表示结束会话成功。
1 2 3 4
PG_TERMINATE_BACKEND ---------------------- t (1 row)
显示类似如下信息,表示用户执行了结束当前会话的操作。1 2
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.”
1 2 3
FATAL: terminating connection due to administrator command FATAL: terminating connection due to administrator command The connection to the server was lost. Attempting reset: Succeeded.
- GaussDB连接_华为Gaussdb_高斯数据库连接_华为云
- GaussDB分析_GaussDB数据库分析_高斯数据库分析_华为云
- GaussDB监控_GaussDB数据库监控_高斯数据库监控_华为云
- GaussDB查看表大小_GaussDB查询表空间_高斯数据库查看表大小-华为云
- GaussDB视频教程_gaussdb查看表结构语句_高斯数据库视频教程_华为云
- GaussDB数据库入门_华为高斯数据库_新建高斯数据库_高斯语法_高斯数据库协议
- GaussDB查看表字段_GaussDB查看表所在节点_高斯数据库查看表字段-华为云
- GaussDB MPP_高斯数据库查看建表语句_高斯数据库 MPP_华为云
- GaussDB数据库的使用现状_GaussDB最大的优势_高斯数据库的使用现状
- 如何查看Flexus云服务详细信息