openGuass 系统对象的获取

1、获取用户当前的所有数据库列表

通常,在大多数基于 PostgreSQL 的系统中,包括 openGauss,你可以使用 pg_catalog 模式下的系统表来查询数据库列表。然而,openGauss 可能会有些许不同,所以最好的做法是查阅 openGauss 的官方文档或使用以下 SQL 查询作为起点:

sql 复制代码
 SELECT datname AS "Database"  
 FROM pg_catalog.pg_database  
 WHERE datallowconn = true  
   AND NOT datistemplate;

2、获取系统所有的表空间名称

在 openGauss 数据库中,要获取所有的表空间信息,你可以查询系统表来检索这些信息。openGauss 的系统表结构与 PostgreSQL 类似,因为 openGauss 是基于 PostgreSQL 的一个分支。

要获取表空间信息,你可以查询 pg_tablespace 系统表。以下是一个 SQL 查询示例,该查询将返回 openGauss 中所有表空间的信息:

sql 复制代码
SELECT   
 spcname
FROM   
 pg_catalog.pg_tablespace;

3、获取用户和角色列表

在 openGauss 数据库中,要获取所有的用户和角色列表,你可以查询系统目录表 pg_rolespg_authid(因为 pg_roles 通常是 pg_authid 的一个视图)。这些表包含了关于数据库用户和角色的信息。

以下是一个 SQL 查询示例,用于获取 openGauss 中所有的用户和角色列表

markdown 复制代码
SELECT   
 * 
FROM   
    pg_catalog.pg_roles  

4、获取一个数据库的模式列表

在 openGauss 数据库中,要查询一个特定数据库下的模式(schema)列表,你可以使用 SQL 查询来检索 pg_namespace 系统表。这个表包含了数据库中所有模式的信息。

sql 复制代码
SELECT nspname AS schema_name  
FROM pg_namespace  
WHERE nspname NOT IN ('pg_catalog', 'information_schema') -- 排除系统模式和信息模式  
ORDER BY nspname;

5、获取一个模式下的函数和存储过程个数

sql 复制代码
select * from information_schema.routines where routine_schema = 'information_schema'

6、获取一个模式下的表的总数

sql 复制代码
SELECT COUNT(*) AS table_count  
FROM pg_tables  
WHERE schemaname = 'information_schema' 

7、获取一个表的列名信息

sql 复制代码
SELECT   
    attname AS column_name,  
    format_type(atttypid, atttypmod) AS data_type  
FROM   
    pg_attribute   
JOIN   
    pg_class ON attrelid = pg_class.oid   
JOIN   
    pg_namespace ON relnamespace = pg_namespace.oid  
WHERE   
    nspname = 'information_schema'   
    AND relname = 'sql_features'  
    AND attnum > 0   
    AND NOT attisdropped  
ORDER BY   
    attnum;
    

8、 获取一个表的索引信息

在 openGauss 数据库中,要获取一个表的索引信息,你可以查询 pg_indexes 视图,但这会返回一个格式化的字符串列表,可能不够详细。更详细的索引信息可以从 pg_classpg_index 和其他系统目录中查询得到。

ini 复制代码
SELECT * FROM pg_indexes WHERE tablename = 'employees';

9、获取一个表的约束信息

sql 复制代码
SELECT conname, contype
FROM pg_constraint
WHERE conrelid = (SELECT oid FROM pg_class WHERE relname = 'employees');

10、获取一个表的ddl语句

arduino 复制代码
SELECT pg_get_tabledef('employees');

11、获取一个表中列的精度和标度

sql 复制代码
SELECT attname, atttypmod
FROM pg_attribute
WHERE attrelid = (SELECT oid FROM pg_class WHERE relname = 'employees') AND attnum > 0;

12、获取一个模式下的所有序列名称

ini 复制代码
SELECT sequence_name
FROM information_schema.sequences
WHERE sequence_schema = 'public';

13、获取一模式下所有的视图名称

ini 复制代码
SELECT viewname
FROM pg_views
WHERE schemaname = 'public';

14、获取一个模式下所有外表名称

sql 复制代码
SELECT relname
FROM pg_class
WHERE relkind = 'f' AND relnamespace = (SELECT oid FROM pg_namespace WHERE nspname = 'your_schema_name');

15、获取一个模式下的所有触发器名称

sql 复制代码
SELECT tgname FROM pg_trigger WHERE tgrelid IN (SELECT oid FROM pg_class WHERE relnamespace = (SELECT oid FROM pg_namespace WHERE nspname = 'your_schema_name'));

16、获取一个表的索引的ddl语句

ini 复制代码
SELECT indexdef
FROM pg_indexes
WHERE tablename = 'employees' AND schemaname = 'public';
相关推荐
Iced_Sheep1 小时前
干掉 if else 之策略模式
后端·设计模式
XINGTECODE1 小时前
海盗王集成网关和商城服务端功能golang版
开发语言·后端·golang
程序猿进阶1 小时前
堆外内存泄露排查经历
java·jvm·后端·面试·性能优化·oom·内存泄露
FIN技术铺1 小时前
Spring Boot框架Starter组件整理
java·spring boot·后端
凡人的AI工具箱2 小时前
15分钟学 Go 第 60 天 :综合项目展示 - 构建微服务电商平台(完整示例25000字)
开发语言·后端·微服务·架构·golang
先天牛马圣体2 小时前
如何提升大型AI模型的智能水平
后端
java亮小白19972 小时前
Spring循环依赖如何解决的?
java·后端·spring
2301_811274312 小时前
大数据基于Spring Boot的化妆品推荐系统的设计与实现
大数据·spring boot·后端
草莓base3 小时前
【手写一个spring】spring源码的简单实现--容器启动
java·后端·spring
Ljw...3 小时前
表的增删改查(MySQL)
数据库·后端·mysql·表的增删查改