PostgreSQL中有没有类似Oracle的dba_objects系统视图

PostgreSQL中有没有类似Oracle的dba_objects系统视图

在PostgreSQL中,没有一个完全集成了所有对象信息的视图(类似于Oracle中的DBA_OBJECTS)。但是,PostgreSQL提供了一些系统目录表和视图,可以用来获取数据库对象的信息。这些系统目录表和视图包括但不限于以下内容:

  1. pg_class: 存储关系(表、索引、序列、视图等)的基本信息。
  2. pg_tables: 包含所有用户定义的表的信息。
  3. pg_views: 包含视图的信息。
  4. pg_indexes: 包含索引的信息。
  5. information_schema.tables: 标准SQL视图,包括表的信息。
  6. information_schema.views: 标准SQL视图,包括视图的信息。
  7. information_schema.columns: 包含所有列的信息。

你可以使用这些视图和表来查询不同类型的数据库对象信息。例如:

查询所有表的信息

sql 复制代码
SELECT * FROM information_schema.tables
WHERE table_schema NOT IN ('information_schema', 'pg_catalog');

查询所有视图的信息

sql 复制代码
SELECT * FROM information_schema.views
WHERE table_schema NOT IN ('information_schema', 'pg_catalog');

查询所有索引的信息

sql 复制代码
SELECT * FROM pg_indexes
WHERE schemaname NOT IN ('pg_catalog', 'information_schema');

查询所有用户定义的表、视图、序列的基本信息

sql 复制代码
SELECT * FROM pg_class
WHERE relkind IN ('r', 'v', 'S') AND relnamespace NOT IN (
    SELECT oid FROM pg_namespace WHERE nspname IN ('pg_catalog', 'information_schema')
);

如果你需要一个整合多个对象信息的视图,可以自己创建一个类似DBA_OBJECTS的视图。例如:

创建自定义视图

sql 复制代码
CREATE VIEW dba_objects AS
SELECT 
    c.oid,
    n.nspname AS schema_name,
    c.relname AS object_name,
    CASE c.relkind
        WHEN 'r' THEN 'table'
        WHEN 'v' THEN 'view'
        WHEN 'i' THEN 'index'
        WHEN 'S' THEN 'sequence'
        WHEN 'c' THEN 'composite type'
        ELSE 'other'
    END AS object_type,
    pg_get_userbyid(c.relowner) AS owner
FROM 
    pg_class c
JOIN 
    pg_namespace n ON c.relnamespace = n.oid
WHERE 
    n.nspname NOT IN ('pg_catalog', 'information_schema');

通过这种方式,你可以灵活地查询数据库中的各种对象,并根据具体需求进行筛选和整理。

相关推荐
小此方2 小时前
Re:Linux系统篇(二十六)进程篇·十一:从底层原理到 exec* 家族:彻底搞懂 Linux 进程程序替换
linux·运维·服务器
曹牧7 小时前
Oracle:前缀匹配之REGEXP_LIKE
数据库·oracle
码农小白AI9 小时前
AI报告审核加速融入自动化实验室:IACheck破解智能设备时代报告管理新挑战
运维·人工智能·自动化
utf8mb4安全女神9 小时前
克隆的虚拟机怎么更改ip地址
运维
暴躁小师兄数据学院10 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_10 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim10 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
万能的知了10 小时前
服务器托管 vs 云主机 vs 裸金属:一个决策故事
运维·服务器·云计算
杨云龙UP11 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone11 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb