Postgresql 系统表作用解释
作者:逍遥德
这篇文章主要介绍了Postgresql 系统表作用解释,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
postgresql 系统表有哪些,作用是什么
了解 PostgreSQL 的系统表(System Catalogs)有哪些,以及它们各自的核心作用。PostgreSQL 的系统表是存储数据库元数据(如表、字段、索引、约束、用户等信息)的核心表,所有数据库对象的定义都记录在这里,我会按功能分类梳理核心系统表,并说明它们的作用和常用场景。
一、核心系统表分类及作用
PostgreSQL 的系统表都位于 pg_catalog 模式下(可省略模式名直接查询),以下是最常用的核心表,按功能分组:
1. 数据库与模式相关
| 系统表名 | 核心作用 |
|---|---|
| pg_database | 存储数据库实例中所有数据库的信息(如数据库名、OID、所有者、编码、表空间) |
| pg_namespace | 存储数据库中的所有模式(Schema) 信息(如模式名、OID、所有者、权限) |
查询示例:
-- 查看所有数据库 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 是系统隐藏字段)。
查询示例:
-- 查看 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 表示主键索引。
查询示例:
-- 查看 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 | 存储对象的权限分配信息(哪些用户对哪些对象有哪些权限) |
查询示例:
-- 查看所有用户 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、状态) |
查询示例:
-- 查看当前所有活跃会话 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:查询索引信息
示例:
-- 用信息模式查询 users 表的字段 SELECT column_name, data_type, is_nullable FROM information_schema.columns WHERE table_name = 'users' AND table_schema = 'public';
三、系统表使用建议
- 新手优先用信息模式:语法更通用,无需记忆系统表的 OID 关联逻辑,降低学习成本。
- 高级场景用原生系统表:如需获取更底层的信息(如索引物理属性、锁详情),原生系统表更全面。
- 避免直接修改系统表:系统表由 PostgreSQL 自动维护,手动修改可能导致数据库损坏,管理对象应使用
CREATE/ALTER/DROP命令。 - 常用元数据查询可封装函数:比如封装 “查询表的所有约束”“查询表的索引” 等函数,简化日常使用。
总结
- 核心系统表分类:数据库 / 模式(pg_database/pg_namespace)、表 / 字段(pg_class/pg_attribute)、约束 / 索引(pg_constraint/pg_index)、用户 / 权限(pg_roles/pg_permissions)、监控 / 锁(pg_stat_activity/pg_locks)是最常用的几类。
- 信息模式优势:基于系统表封装的标准视图,语法通用、易读,适合新手和跨数据库场景。
- 使用原则:系统表用于查询元数据,禁止手动修改;优先用信息模式,底层需求用原生系统表。
到此这篇关于Postgresql 系统表作用解释的文章就介绍到这了,更多相关Postgresql 系统表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
