暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

GaussDB查看系统表

uuuu 2023-08-22
174

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

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

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

  • 兼容PostgreSQL的系统表和系统视图

    这类系统表和系统视图具有PG前缀。

  • GaussDB Kernel内核新增的系统表和系统视图

    这类系统表和系统视图具有GS前缀。

  • 实现Oracle兼容的系统表和系统视图

    这类系统表和系统视图具有ALL、DBA、USER或PV前缀。

查看数据库中包含的表

在public Schema下新建五张表:

gaussdb=#  CREATE TABLE public.search_table_t1(a int) distribute by hash(a);
CREATE TABLE
gaussdb=#  CREATE TABLE public.search_table_t2(b int) distribute by hash(b);
CREATE TABLE
gaussdb=#  CREATE TABLE public.search_table_t3(c int) distribute by hash(c);
CREATE TABLE
gaussdb=#  CREATE TABLE public.search_table_t4(d int) distribute by hash(d);
CREATE TABLE
gaussdb=#  CREATE TABLE public.search_table_t5(e int) distribute by hash(e);
CREATE TABLE


在PG_TABLES系统表中查看public Schema中包含的前缀为search_table的表。

gaussdb=#  SELECT distinct(tablename) FROM pg_tables WHERE SCHEMANAME = 'public' AND TABLENAME LIKE 'search_table%';


结果类似如下:

    tablename
-----------------
 search_table_t1
 search_table_t2
 search_table_t3
 search_table_t4
 search_table_t5
(5 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 
---------+----------+-------------+----------+-----------+---------+----------+----------+----------+--------------+------
-------+------------+-----------+-----------+----------------+-----------------
 roach   |       10 | t           | t        | t         | t       | ******** |          |          | default_pool |      
0      |            |           |           |                | 
(1 row)


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

通过视图PG_STAT_ACTIVITY可以查看正在运行的查询语句。方法如下:

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

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

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

    • 兼容PostgreSQL的系统表和系统视图

      这类系统表和系统视图具有PG前缀。

    • GaussDB Kernel内核新增的系统表和系统视图

      这类系统表和系统视图具有GS前缀。

    • 实现Oracle兼容的系统表和系统视图

      这类系统表和系统视图具有ALL、DBA、USER或PV前缀。

    查看数据库中包含的表

    在public Schema下新建五张表:
    gaussdb=#  CREATE TABLE public.search_table_t1(a int) distribute by hash(a);
    CREATE TABLE
    gaussdb=#  CREATE TABLE public.search_table_t2(b int) distribute by hash(b);
    CREATE TABLE
    gaussdb=#  CREATE TABLE public.search_table_t3(c int) distribute by hash(c);
    CREATE TABLE
    gaussdb=#  CREATE TABLE public.search_table_t4(d int) distribute by hash(d);
    CREATE TABLE
    gaussdb=#  CREATE TABLE public.search_table_t5(e int) distribute by hash(e);
    CREATE TABLE
    在PG_TABLES系统表中查看public Schema中包含的前缀为search_table的表。
    gaussdb=#  SELECT distinct(tablename) FROM pg_tables WHERE SCHEMANAME = 'public' AND TABLENAME LIKE 'search_table%';
    
    结果类似如下:
        tablename
    -----------------
     search_table_t1
     search_table_t2
     search_table_t3
     search_table_t4
     search_table_t5
    (5 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 
    ---------+----------+-------------+----------+-----------+---------+----------+----------+----------+--------------+------
    -------+------------+-----------+-----------+----------------+-----------------
     roach   |       10 | t           | t        | t         | t       | ******** |          |          | default_pool |      
    0      |            |           |           |                | 
    (1 row)
    

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

    通过视图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
      ----------+---------+--------+-----------------
       testdb | Ruby    | active | 140298793514752
       testdb | Ruby    | active | 140298718004992
       testdb | Ruby    | idle   | 140298650908416
       testdb | Ruby    | idle   | 140298625742592
       testdb | omm | active | 140298575406848
      (5 rows)
      

      如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。

      如果仅需要查看非空闲的查询语句,则使用如下命令查看:

      SELECT datname, usename, state, pid FROM pg_stat_activity WHERE state != 'idle';
      
    3. 若需要取消运行时间过长的查询,通过PG_TERMINATE_BACKEND函数,根据线程ID(即2中查询结果的pid字段)结束会话。
      SELECT PG_TERMINATE_BACKEND(140298793514752);
      

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

      PG_TERMINATE_BACKEND
      ----------------------
       t
      (1 row)
      
      显示类似如下信息,表示用户执行了结束当前会话的操作。
      FATAL:  terminating connection due to administrator command
      FATAL:  terminating connection due to administrator command
      
      说明:

      1. gsql客户端使用PG_TERMINATE_BACKEND函数结束当前正在执行会话的后台线程时,如果当前的用户是初始用户,客户端不会退出而是自动重连,即还会返回“The connection to the server was lost. Attempting reset: Succeeded.”;否则客户端会重连失败,即返回“The connection to the server was lost. Attempting reset: Failed.”。这是因为只有初始用户可以免密登录,普遍用户不能免密登录,从而重连失败。

      2. 对于使用PG_TERMINATE_BACKEND函数结束非活跃的后台线程时。如果打开了线程池,此时空闲的会话没有线程ID,无法结束会话。非线程池模式下,结束的会话不会自动重连。

    设置参数track_activities为on。


    SET track_activities = on;
    


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


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


    SELECT datname, usename, state,pid FROM pg_stat_activity;
    


     datname  | usename | state  |       pid
    ----------+---------+--------+-----------------
     testdb | Ruby    | active | 140298793514752
     testdb | Ruby    | active | 140298718004992
     testdb | Ruby    | idle   | 140298650908416
     testdb | Ruby    | idle   | 140298625742592
     testdb | omm | active | 140298575406848
    (5 rows)
    


    如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。

    如果仅需要查看非空闲的查询语句,则使用如下命令查看:

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



  3. 若需要取消运行时间过长的查询,通过PG_TERMINATE_BACKEND函数,根据线程ID(即2中查询结果的pid字段)结束会话。


    SELECT PG_TERMINATE_BACKEND(140298793514752);
    


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

    PG_TERMINATE_BACKEND
    ----------------------
     t
    (1 row)
    


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

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


    说明:

    1. gsql客户端使用PG_TERMINATE_BACKEND函数结束当前正在执行会话的后台线程时,如果当前的用户是初始用户,客户端不会退出而是自动重连,即还会返回“The connection to the server was lost. Attempting reset: Succeeded.”;否则客户端会重连失败,即返回“The connection to the server was lost. Attempting reset: Failed.”。这是因为只有初始用户可以免密登录,普遍用户不能免密登录,从而重连失败。

    2. 对于使用PG_TERMINATE_BACKEND函数结束非活跃的后台线程时。如果打开了线程池,此时空闲的会话没有线程ID,无法结束会话。非线程池模式下,结束的会话不会自动重连。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论