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');

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

相关推荐
头发那是一根不剩了3 分钟前
Ubuntu 离线环境升级 OpenSSH 修复漏洞
linux·运维·ubuntu
huan1991106 分钟前
nacos2.3.0 接入pgsql或其他数据库
数据库
别退11 分钟前
WSL2安装Freesurfer
linux·运维·服务器
runepic21 分钟前
GeoServer在CentOS部署中文乱码显示方框终极解决方案
linux·运维·centos·geoserver
changhong198626 分钟前
mybatisPlus打印sql配置
数据库·sql
假如梵高是飞行员27 分钟前
Ubuntu 磁盘扩容
linux·运维·ubuntu
l1t29 分钟前
用官方安装脚本安装duckdb 1.5并测试加载各种插件
数据库·docker·postgresql·kylin
jinanmichael30 分钟前
Mybatis控制台打印SQL执行信息(执行方法、执行SQL、执行时间)
数据库·sql·mybatis
江湖有缘30 分钟前
从零搭建私密空间:使用 Docker一键部署DailyTxT加密日记系统
运维·docker·容器
我爱学习好爱好爱33 分钟前
ELK日志分析平台(四):Kibana 7.17.10 部署与基本配置(与ES01同机,基于Rocky Linux 9.6)
linux·运维·elk