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

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

查看系统表

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

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

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

兼容PostgreSQL的系统表和系统视图
这类系统表和系统视图具有PG前缀。

GaussDB内核新增的系统表和系统视图
这类系统表和系统视图具有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可以查看正在运行的查询语句。方法如下:

设置参数track_activities为on。

SET track_activities = on;

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

查看正在运行的查询语句。以查看正在运行的查询语句所连接的数据库名、执行查询的用户、查询状态及查询对应的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’;

若需要取消运行时间过长的查询,通过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

说明:

gsql客户端使用PG_TERMINATE_BACKEND函数结束当前正在执行会话的后台线程时,如果当前的用户是初始用户,客户端不会退出而是自动重连,即返回“The connection to the server was lost. Attempting reset: Succeeded.”。否则客户端会重连失败,即返回“The connection to the server was lost. Attempting reset: Failed.”。这是因为只有初始用户可以免密登录,普通用户不能免密登录,从而重连失败。
对于使用PG_TERMINATE_BACKEND函数结束非活跃的后台线程时。如果打开了线程池,此时空闲的会话没有线程ID,无法结束会话。非线程池模式下,结束的会话不会自动重连。

<think>嗯,用户想要了解高斯数据库(GaussDB系统视图的详细说明。让我整理一下引用中的关键信息。 用户引用了五篇资料,其中引用[2]、[3]、[5]特别重要。引用[2]展示了一个具体查询示例,在PG_TABLES系统中查找特定名;引用[3]解释了系统视图的前缀命名规则,提到adm_、db_、my_三类视图分别对应Oracle的dba_、all_、user_;引用[5]则强调系统的权限管理风险,并详细说明了三类视图的访问权限差异。 用户明确要求"详细说明",所以需要展开三个维度:首先是基础概念(系统/视图的作用),其次是核心分类(三类视图的对比),最后是使用规范(权限风险)。特别要注意引用[5]的警告——人为修改系统可能导致集群不可用,这个风险提示必须突出。 关于内容组织:开头应该定义系统视图的核心作用(引用[1]提到物化视图时暗示了数据管理的重要性)。主体部分需要格对比三类视图,包含Oracle命名对照(引用[3])访问权限说明(引用[5])。最后补充两个实战例子:一个是引用[2]的PG_TABLES查询,另一个是引用[3]的adm_视图查询,这样用户能立即上手操作。 安全提示要放在显眼位置。引用[5]三次强调权限风险,考虑用⚠️符号强化警示。另外,用户可能混淆GaussDB的两种版本(兼容PostgreSQL/MySQL),但当前问题聚焦系统,暂无需展开(引用[4]的兼容性格可保留作伏笔)。 相关问题设计要引导深入:系统查询工具(延伸引用[2])、Oracle迁移对照(呼应引用[3])、视图维护(关联引用[5]风险提示),形成知识闭环。 </think>以下是关于 GaussDB 系统系统视图的详细说明,结合核心功能安全性要求整理: --- ### 一、核心概念 1. **系统** - 存储数据库元数据(如结构、用户权限、统计信息等) - 命名以 `pg_` 为前缀(如 `pg_tables`、`pg_views`) - **严禁直接修改**:增删改操作可能导致集群崩溃或数据异常[^5] 2. **系统视图** - 提供系统的可读性抽象层,分为三类: | 前缀 | 对应 Oracle 视图 | 权限范围 | 访问权限 | |------|------------------|------------------------------|----------------| | `adm_` | `dba_` | **所有**数据库对象 | 仅系统管理员 | | `db_` | `all_` | 当前用户**有权限访问**的对象 | 普通用户可访问 | | `my_` | `user_` | 当前用户**所属**的对象 | 普通用户可访问 | --- ### 二、关键功能与使用 #### 1. 常用系统示例 - **`pg_tables`**:查询所有信息 ```sql -- 检索 public Schema 中以 "search_table" 开头的 SELECT DISTINCT(tablename) FROM pg_tables WHERE schemaname = 'public' AND tablename LIKE 'search_table%'; [^2] ``` - **`pg_views`**:查看视图定义 - **`pg_stat_activity`**:监控当前会话 #### 2. 系统视图应用场景 - **管理员视图 (`adm_`)**: ```sql -- 查看所有用户对象 (需管理员权限) SELECT * FROM adm_tables; ``` - **用户视图 (`my_`)**: ```sql -- 查看当前用户拥有的 SELECT * FROM my_tables; ``` --- ### 三、安全与规范 1. **禁止操作** - 外键相关的系统字段**不支持修改**[^5] - 手动更新系统可能导致集群不可用 2. **权限控制** - `adm_` 视图仅限管理员访问 - `db_`/`my_` 视图向普通用户开放[^5] 3. **数据来源** - `adm_` 视图数据来自**基非敏感字段** - 部分敏感元数据对普通用户不可见[^5] --- ### 四、与 Oracle 的兼容性对比 | 功能 | GaussDB | Oracle | |---------------------|-----------------------|----------------| | 系统视图命名 | `adm_`, `db_`, `my_` | `dba_`, `all_`, `user_` | | 架构扩展性 | 分布式水平扩展 | RAC 垂直扩展 | | 权限隔离 | 三级视图分层管控 | 类似角色分级 | > ⚠️ **重要提示**:GaussDB系统字段类型需参考官方文档,修改权限可能导致审计异常或安全漏洞[^5][^4]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值