Postgresql 系统表作用解释

postgresql 系统表有哪些,作用是什么

了解 PostgreSQL 的系统表(System Catalogs)有哪些,以及它们各自的核心作用。PostgreSQL 的系统表是存储数据库元数据(如表、字段、索引、约束、用户等信息)的核心表,所有数据库对象的定义都记录在这里,我会按功能分类梳理核心系统表,并说明它们的作用和常用场景。

一、核心系统表分类及作用

PostgreSQL 的系统表都位于 pg_catalog 模式下(可省略模式名直接查询),以下是最常用的核心表,按功能分组:

1. 数据库与模式相关
系统表名 核心作用
pg_database 存储数据库实例中所有数据库的信息(如数据库名、OID、所有者、编码、表空间)
pg_namespace 存储数据库中的所有模式(Schema) 信息(如模式名、OID、所有者、权限)

查询示例

sql

sql 复制代码
-- 查看所有数据库
SELECT datname, datowner, encoding FROM pg_database;

-- 查看当前数据库的所有模式
SELECT nspname, nspowner FROM pg_namespace;
2. 表 / 视图 / 索引等对象相关
系统表名 核心作用
pg_class 存储所有关系型对象(表、视图、索引、序列、物化视图等)的核心信息,是最核心的系统表之一
pg_attribute 存储所有字段(列) 的信息(如字段名、所属表 OID、数据类型、是否可为空、默认值)
pg_type 存储所有数据类型的信息(内置类型如 int/text,自定义类型都在这里)

关键说明

  • pg_class.relkind 字段区分对象类型:r= 普通表,v= 视图,i= 索引,s= 序列,m= 物化视图。
  • pg_attribute.attnum 为字段编号(>0 是普通字段,0 是表 oid,-1/-2 是系统隐藏字段)。

查询示例

sql

sql 复制代码
-- 查看 public 模式下的所有普通表
SELECT relname AS table_name 
FROM pg_class 
WHERE relkind = 'r' 
AND relnamespace = (SELECT oid 
            FROM pg_namespace 
            WHERE nspname = 'public');

-- 查看 users 表的所有字段及类型
SELECT 
    a.attname AS column_name,
    t.typname AS data_type,
    a.attnotnull AS is_not_null
FROM pg_attribute a
JOIN pg_type t ON a.atttypid = t.oid
WHERE a.attrelid = (SELECT oid 
            FROM pg_class WHERE relname = 'users') 
    AND a.attnum > 0;
3. 约束与索引相关
系统表名 核心作用
pg_constraint 存储所有约束信息(主键、外键、唯一约束、检查约束、默认值约束)
pg_index 存储索引的详细信息(所属表、索引字段、是否唯一、是否主键、索引类型)

关键说明

  • pg_constraint.contype 区分约束类型:p= 主键,u= 唯一约束,f= 外键,c= 检查约束,d= 默认值约束。
  • pg_index.indisunique = true 表示唯一索引,indisprimary = true 表示主键索引。

查询示例

sql

sql 复制代码
-- 查看 users 表的所有约束
SELECT conname, contype, conkey 
FROM pg_constraint 
WHERE conrelid = (SELECT oid FROM pg_class WHERE relname = 'users');

-- 查看 users 表的所有唯一索引
SELECT indexrelname AS index_name 
FROM pg_index 
JOIN pg_class t ON pg_index.indrelid = t.oid 
WHERE t.relname = 'users' AND indisunique = true;
4. 用户与权限相关
系统表名 核心作用
pg_roles 存储数据库中所有角色 / 用户 / 组的信息(用户名、密码哈希、权限、是否超级用户)
pg_authid pg_roles 类似,但包含敏感信息(如密码),仅超级用户可访问
pg_permissions 存储对象的权限分配信息(哪些用户对哪些对象有哪些权限)

查询示例

sql

sql 复制代码
-- 查看所有用户
SELECT rolname, rolsuper, rolcreaterole FROM pg_roles;

-- 查看 users 表的权限分配
SELECT grantee, privilege_type 
FROM information_schema.table_privileges 
WHERE table_name = 'users';
5. 其他常用系统表
系统表名 核心作用
pg_tablespace 存储表空间信息(数据库物理存储位置)
pg_stat_user_tables 存储用户表的统计信息(如行数、读写次数、扫描次数,用于性能分析)
pg_locks 存储当前数据库的锁信息(排查锁等待、死锁问题)
pg_stat_activity 存储当前数据库连接 / 会话信息(谁在连接、执行什么 SQL、状态)

查询示例

sql

sql 复制代码
-- 查看当前所有活跃会话
SELECT usename, datname, query, state 
FROM pg_stat_activity 
WHERE state = 'active';

-- 查看表的行数和读写统计
SELECT relname, n_live_tup AS row_count, seq_scan AS full_scan_count 
FROM pg_stat_user_tables 
WHERE relname = 'users';

二、信息模式(Information Schema):更友好的元数据查询方式

除了原生系统表,PostgreSQL 还提供了 Information Schema(信息模式),它是符合 SQL 标准的视图集合,封装了底层系统表,语法更通用、更易读,适合跨数据库兼容场景。

常用的信息模式视图:

  • information_schema.tables:查询表信息
  • information_schema.columns:查询字段信息
  • information_schema.table_constraints:查询约束信息
  • information_schema.indexes:查询索引信息

示例

sql

sql 复制代码
-- 用信息模式查询 users 表的字段
SELECT column_name, data_type, is_nullable 
FROM information_schema.columns 
WHERE table_name = 'users' AND table_schema = 'public';

三、系统表使用建议

  1. 新手优先用信息模式:语法更通用,无需记忆系统表的 OID 关联逻辑,降低学习成本。
  2. 高级场景用原生系统表:如需获取更底层的信息(如索引物理属性、锁详情),原生系统表更全面。
  3. 避免直接修改系统表 :系统表由 PostgreSQL 自动维护,手动修改可能导致数据库损坏,管理对象应使用 CREATE/ALTER/DROP 命令。
  4. 常用元数据查询可封装函数:比如封装 "查询表的所有约束""查询表的索引" 等函数,简化日常使用。

总结

  1. 核心系统表分类:数据库 / 模式(pg_database/pg_namespace)、表 / 字段(pg_class/pg_attribute)、约束 / 索引(pg_constraint/pg_index)、用户 / 权限(pg_roles/pg_permissions)、监控 / 锁(pg_stat_activity/pg_locks)是最常用的几类。
  2. 信息模式优势:基于系统表封装的标准视图,语法通用、易读,适合新手和跨数据库场景。
  3. 使用原则:系统表用于查询元数据,禁止手动修改;优先用信息模式,底层需求用原生系统表。
相关推荐
MonkeyKing_sunyuhua2 小时前
ES文档序号写错的问题的修复
java·数据库·elasticsearch
饱饱要坚持可持续发展观2 小时前
Liquibase preConditions 执行前判断详解
数据库·liquibase
代码煮茶君2 小时前
MySQL 数据库死锁及核心机制全解析
android·数据库·mysql
咕噜企业分发小米3 小时前
豆包大模型在药物研发中的知识检索效率如何?
java·开发语言·数据库
lynnlovemin3 小时前
SpringBoot+SSE构建AI实时流式对话系统:原理剖析与代码实战
人工智能·spring boot·后端·ai·sse
LaughingZhu3 小时前
Product Hunt 每日热榜 | 2026-01-20
数据库·人工智能·经验分享·神经网络·搜索引擎·chatgpt
SJLoveIT3 小时前
sql注入攻击的防御思路总结
数据库·sql
偷星星的贼113 小时前
如何为开源Python项目做贡献?
jvm·数据库·python
这就是佬们吗3 小时前
力扣---leetcode48
java·笔记·后端·算法·leetcode·idea