0

0

postgresql系统catalog如何维护_postgresql系统表结构说明

尊渡假赌尊渡假赌尊渡假赌

尊渡假赌尊渡假赌尊渡假赌

发布时间:2025-11-23 20:30:03

|

730人浏览过

|

来源于php中文网

原创

PostgreSQL的系统catalog是存储元数据的核心结构,包含数据库对象信息。它由pg_catalog模式下的系统表和视图组成,如pg_class记录表、索引等对象,pg_namespace存储schema信息,pg_attribute保存列定义,pg_type管理数据类型,pg_index描述索引,pg_constraint存储约束,pg_roles记录用户角色,pg_database维护数据库列表。系统自动更新这些表,用户应通过系统视图(如pg_tables、pg_indexes)查询,避免直接修改。定期执行VACUUM和ANALYZE可维护catalog健康,确保性能稳定。

postgresql系统catalog如何维护_postgresql系统表结构说明

PostgreSQL 的系统 catalog(系统目录)是数据库内部用于存储元数据的核心结构,它记录了所有数据库对象的信息,比如表、索引、视图、函数、用户权限等。理解系统 catalog 的结构和维护方式,有助于深入掌握 PostgreSQL 的运行机制,也对性能调优、故障排查和工具开发有帮助。

系统 catalog 是什么

PostgreSQL 使用一组系统表和系统视图来管理数据库的元数据,这些统称为系统 catalog。它们存在于 pg_catalog 模式中,普通用户通常不会直接操作这些表,但可以通过查询系统视图来获取数据库结构信息。

这些系统表本身也是用 PostgreSQL 表实现的,但被内部机制保护,不允许直接 INSERT、UPDATE 或 DELETE(除非在特殊模式下,如 bootstrap 模式)。所有对 schema 的变更(如 CREATE TABLE、GRANT 等)都会由 PostgreSQL 自动更新相应的系统 catalog 记录。

常见系统表及其作用

以下是一些关键的系统表及其用途说明:

pg_class

存储所有“关系”对象,包括表、索引、序列、TOAST 表等。主要字段:

  • relname:对象名称
  • relkind:对象类型(r=普通表,i=索引,S=序列,v=视图,m=物化视图,c=复合类型,t=TOAST 表)
  • relnamespace:所属命名空间(即 schema 的 OID)
  • relowner:所有者 OID
  • reltuples:估算的行数(由 ANALYZE 更新)
  • relpages:占用的磁盘页数
pg_namespace

存储 schema 信息。字段包括:

  • nspname:schema 名称
  • oid:唯一标识符,被其他系统表引用
pg_attribute

存储表的列信息(每个列一条记录),关键字段:

  • attrelid:所属表的 OID(指向 pg_class.oid)
  • attname:列名
  • atttypid:数据类型的 OID(指向 pg_type)
  • attnum:列的序号(正数为用户列,负数为系统隐含列)
  • attisdropped:是否已被删除(ALTER DROP COLUMN 后标记)
pg_type

定义所有数据类型,包括内置类型和用户自定义类型。

pg_index

描述索引的元数据,如:

Type Studio
Type Studio

一个视频编辑器,提供自动转录、自动生成字幕、视频翻译等功能

下载
  • indexrelid:索引在 pg_class 中的 OID
  • indrelid:被索引表的 OID
  • indkey:索引键对应的列编号数组
  • indisprimary:是否为主键
pg_constraint

存储约束信息(主键、外键、唯一、检查等)。

pg_roles

记录数据库角色(用户)信息,替代旧的 pg_user 视图。

pg_database

存储数据库列表,每个数据库一条记录,包含其 OID、编码、模板属性等。

系统视图的使用

虽然系统表保存原始数据,但通常建议通过系统视图来查询,因为它们更易读且做了语义封装。例如:

  • pg_tables:显示所有可访问的表
  • pg_indexes:索引信息的可读展示
  • pg_views:查看视图定义
  • information_schema:SQL 标准兼容的元数据视图,跨数据库通用

示例:查看当前数据库所有表的大小

SELECT tablename, pg_size_pretty(pg_total_relation_size(tablename::text)) 
FROM pg_tables 
WHERE schemaname = 'public';

系统 catalog 的维护机制

PostgreSQL 自动维护系统 catalog,但某些操作需要手动干预或定期执行:

  • VACUUM:清理 dead 元组,回收空间。系统表也会产生 dead 元组,因此需定期 vacuum(尤其是频繁 DDL 操作时)
  • ANALYZE:更新统计信息(如 pg_class.reltuples),供查询规划器使用。执行 ANALYZE 可刷新表行数估算
  • REINDEX SYSTEM:重建某个数据库的全部系统索引(如 pg_class_oid_index)
  • initdb:初始化集群时创建初始的系统 catalog 结构

注意:不要尝试手动修改系统表内容。错误的写入可能导致数据库损坏。若需深度调试,可在单用户模式下启动并谨慎操作。

基本上就这些。系统 catalog 是 PostgreSQL 的“自描述”核心,了解其结构能提升对数据库行为的理解,但在生产环境中应以只读方式使用。日常维护依赖自动机制,配合 VACUUM 和 ANALYZE 即可保持健康状态。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

679

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

573

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

415

2024.04.29

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

HTML+CSS基础与实战
HTML+CSS基础与实战

共132课时 | 9.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号