查看系统表和系统视图

除了创建的表以外,数据库还包含很多系统表。这些系统表包含 VexDB 安装信息以及 VexDB 上运行的各种查询和进程的信息。可以通过查询系统表来收集有关数据库的信息。

系统表和系统视图中每个表的说明指出了表是对所有用户可见还是只对初始化用户可见。必须以初始化用户身份登录才能查询只对初始化用户可见的表。

VexDB 提供了以下类型的系统表和视图:

  • 继承自 PG 的系统表和视图,这类系统表和视图具有 PG 前缀。
  • 继承自 OG 的系统表和视图,这类系统表和视图具有 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_CLASS 系统表存储数据库对象信息及其之间的关系。

SELECT * FROM PG_CLASS WHERE relname = 'object_name';

其中 object_name 表示待查询的对象名称。

查看数据库用户

通过系统表 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 |            |
guest                             |    17103 | f           | f        | f         | f       | ** |          |          | default_p
ool |      0 |            |
vexdb                             |       10 | t           | t        | t         | t       | ** |          |          | default_p
ool |      0 |            |
vexdb                             |    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)

查看和停止正在运行的查询语句

通过系统视图 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 | vexdb   | 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
    
    说明

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

查看数据库参数配置

通过 PG_SETTINGS 视图显示数据库运行时参数的相关信息。

SELECT * FROM PG_SETTINGS WHERE name = 'parameter_name';

其中 parameter_name 是待查询的参数名称。

需要帮助?

扫码添加企业微信
获得专业技术支持

企业微信二维码
🎯 快速响应💡 专业解答