查看系统表和系统视图
除了创建的表以外,数据库还包含很多系统表。这些系统表包含Vastbase安装信息以及Vastbase上运行的各种查询和进程的信息。可以通过查询系统表来收集有关数据库的信息。
系统表和系统视图中指出了表是对所有用户可见还是只对初始化用户可见。必须以初始化用户身份登录才能查询只对初始化用户可见的表。
Vastbase提供了以下类型的系统表和视图:
继承自PG的系统表和视图:这类系统表和视图具有PG前缀。
继承自openGauss的系统表和视图:这类系统表和视图具有GS前缀。
查看数据库中包含的表
在PG_TABLES系统表中查看public schema中包含的所有表。
SELECT distinct(tablename) FROM pg_tables WHERE SCHEMANAME = 'public';
显示类似如下信息:
tablename
-------------------
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 | nodegroup | tempspacelimit | spillspacelimit | u
semonitoradmin | useoperatoradmin | usepolicyadmin
----------+----------+-------------+----------+-----------+---------+----------+----------+----------+--------------+--------+------------+-----------+-----------+----------------+-----------------+--
---------------+------------------+----------------
user2 | 53382 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
user1 | 53378 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
user9 | 20593 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
user8 | 20589 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
user7 | 20585 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
user6 | 20581 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
user5 | 20577 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
user4 | 20573 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
user3 | 20569 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
vbaudit | 34 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
vbadmin | 33 | t | t | t | t | ******** | | | default_pool | 0 | | | | | | f
| f | f
vbsso | 35 | f | f | f | f | ******** | | | default_pool | 0 | | | | | | f
| f | f
vastbase | 10 | t | t | t | t | ******** | | | default_pool | 0 | | | | | | t
| t | t
(13 rows)
查看和停止正在运行的查询语句
通过视图PG_STAT_ACTIVITY可以查看正在运行的查询语句。方法如下:
1、设置参数track_activities为on(当此参数为on时,数据库系统才会收集当前活动查询的运行信息。)。
SET track_activities = on;
2、查看正在运行的查询语句。以查看正在运行的查询语句所连接的数据库名、执行查询的用户、查询状态及查询对应的PID为例:
SELECT datname, usename, state,pid FROM pg_stat_activity;
显示类似如下信息:
datname | usename | state | pid
----------+----------+--------+-----------------
vastbase | vastbase | active | 139855352559360
postgres | vastbase | idle | 139855526815488
postgres | vastbase | idle | 139855510034176
postgres | vastbase | active | 139855543596800
postgres | vastbase | idle | 139855925278464
postgres | vastbase | idle | 139855891715840
postgres | vastbase | idle | 139855942059776
postgres | vastbase | active | 139856025966336
postgres | vastbase | active | 139855908497152
postgres | vastbase | idle | 139855975622400
(10 rows)
如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。
如果仅需要查看非空闲的查询语句,则使用如下命令查看:
SELECT datname, usename, state FROM pg_stat_activity WHERE state != 'idle';
显示类似如下信息:
datname | usename | state
----------+----------+--------
vastbase | vastbase | active
postgres | vastbase | active
postgres | vastbase | active
postgres | vastbase | active
(4 rows)
3、若需要取消运行时间过长的查询,通过PG_TERMINATE_BACKEND函数,根据线程ID结束会话。
SELECT PG_TERMINATE_BACKEND(139855975622400);
显示类似如下信息,表示结束会话成功。
pg_terminate_backend
----------------------
t
(1 row)
显示类似如下信息,表示用户执行了结束当前会话的操作。
FATAL: terminating connection due to administrator command
FATAL: terminating connection due to administrator command
vsql客户端使用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.