查看系统表
“查看系统表和系统视图”中每个表的说明指出了表是对所有用户可见还是只对初始化用户可见。必须以初始化用户身份登录才能查询只对初始化用户可见的表。
openGauss提供了以下类型的系统表和视图:
继承自PG的系统表和视图
这类系统表和视图具有PG前缀。
openGaussl新增的系统表和视图
例如,在PG_TABLES系统表中查看public schema中包含的所有表。
结果类似如下这样:
-------------------
err_hr_staffs
test
err_hr_staffs_ft3
web_returns_p1
mig_seq_table
films4
(6 rows)
通过PG_USER可以查看数据库中所有用户的列表,还可以查看用户ID(USESYSID)和用户权限。
SELECT * FROM pg_user;
usename | usesysid | usecreatedb | usesuper | usecatupd | userepl | passwd | valbegin | valuntil | respool
| parent | spacelimit | useconfig
-----------------------------------+----------+-------------+----------+-----------+---------+----------+----------+----------+----------
dfc22b86afbd9a745668c3ecd0f15ec18 | 17107 | f | f | f | f | ******** | | | default_p
ool | 0 | |
ool | 0 | |
omm | 10 | t | t | t | t | ******** | | | default_p
ool | 0 | |
omm | 16404 | f | f | f | f | ******** | | | default_p
ool | 0 | |
lily | 16482 | f | f | f | f | ******** | | | default_p
ool | 0 | |
jack | 16478 | f | f | f | f | ******** | | | default_p
ool | 0 | |
(6 rows)
通过视图可以查看正在运行的查询语句。方法如下:
设置参数track_activities为on。
查看正在运行的查询语句。以查看正在运行的查询语句所连接的数据库名、执行查询的用户、查询状态及查询对应的PID为例:
SELECT datname, usename, state,pid FROM pg_stat_activity;
----------+---------+--------+-----------------
postgres | Ruby | active | 140298718004992
postgres | Ruby | idle | 140298650908416
postgres | Ruby | idle | 140298625742592
postgres | omm | active | 140298575406848
(5 rows)
如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。
如果仅需要查看非空闲的查询语句,则使用如下命令查看:
SELECT datname, usename, state FROM pg_stat_activity WHERE state != 'idle';
若需要取消运行时间过长的查询,通过PG_TERMINATE_BACKEND函数,根据线程ID结束会话。
显示类似如下信息,表示结束会话成功。
PG_TERMINATE_BACKEND
----------------------
t
(1 row)
FATAL: terminating connection due to administrator command
FATAL: terminating connection due to administrator command