在 PostgreSQL 中,pg_class
是一个系统目录表,用于存储所有关系(如表、索引、视图、序列等)的元数据。pg_class
是数据库系统的重要组成部分,包含了关于每个关系的具体信息。
pg_class
视图字段说明
以下是 pg_class
表中一些主要字段及其说明:
- oid:对象 ID(每个关系的唯一标识)。
- relname:关系(表、索引、视图等)的名字。
- relnamespace:关系所在的命名空间(schema)的 OID。
- reltype:用来存储此表的行类型的类型 OID。
- reloftype:如果表是一个类型表的子表,则为类型表的 OID,否则为零。
- relowner:表所有者的 OID。
- relam:如果是索引,表示索引的访问方法的 OID。
- relfilenode:缺省情况下为对象标识符的文件节点号。
- reltablespace:存储该关系的表空间的 OID。
- relpages:分配的页面数。仅用统计信息更新。
- reltuples:估计的元组数。仅用统计信息更新。
- relallvisible:最后一个确定可见页面的块号。
- reltoastrelid:与此关系关联的 TOAST 表的 OID(如果有)。
- reltoastidxid:与此 TOAST 表关联的索引 OID(如果有)。
- relhasindex:表中是否有索引。
- relisshared:如果是共享表,则为 true。
- relpersistence:应该在数据库关闭期间保存哪些对象 (
p
for permanent,u
for unlogged,t
for temporary)。 - relkind:关系的类型(如
r
for ordinary table,i
for index,S
for sequence,v
for view, etc)。 - relnatts:表的列数。
- relchecks:表的 CHECK 约束的数量。
- relhasrules:如果表有规则,则为 true。
- relhastriggers:如果表有触发器,则为 true。
- relhassubclass:如果表有子表,则为 true。
使用示例
查询所有表信息
可以用以下查询获取所有表的信息:
SELECT * FROM pg_class WHERE relkind = 'r';
- 1
查询所有索引信息
可以用以下查询获取所有索引的信息:
SELECT * FROM pg_class WHERE relkind = 'i';
- 1
查询特定表的信息
根据表名查询特定表的信息:
SELECT * FROM pg_class WHERE relname = 't1';
- 1
查询特定模式下的所有表
可以结合 pg_namespace
表,根据模式过滤表:
SELECT
c.relname,
n.nspname
FROM
pg_class c
JOIN
pg_namespace n ON c.relnamespace = n.oid
WHERE
c.relkind = 'r'
AND n.nspname = 'yewu1';
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
结果输出
white=# SELECT
white-# c.relname,
white-# n.nspname
white-# FROM
white-# pg_class c
white-# JOIN
white-# pg_namespace n ON c.relnamespace = n.oid
white-# WHERE
white-# c.relkind = 'r'
white-# AND n.nspname = 'yewu1';
relname | nspname
---------+---------
t1 | yewu1
t2 | yewu1
t4 | yewu1
(3 rows)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
查询表大小、行数等统计信息
可以通过 pg_class
表中的 relpages
和 reltuples
字段获取表的统计信息:
SELECT
relname,
relpages,
reltuples
FROM
pg_class
WHERE
relkind = 'r';
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
结合其他系统表使用
查询表的所有者信息(结合 pg_roles)
通过结合 pg_roles
表查询表的所有者信息:
SELECT
c.relname,
r.rolname
FROM
pg_class c
JOIN
pg_roles r ON c.relowner = r.oid
WHERE
c.relkind = 'r';
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
查询表的列信息(结合 pg_attribute)
通过结合 pg_attribute
表查询表的列信息:
SELECT
a.attname,
a.atttypid::regtype,
a.attlen,
a.attnotnull
FROM
pg_class c
JOIN
pg_attribute a ON c.oid = a.attrelid
WHERE
c.relname = 't1'
AND a.attnum > 0
AND NOT a.attisdropped;
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
结果输出
white=# SELECT
white-# a.attname,
white-# a.atttypid::regtype,
white-# a.attlen,
white-# a.attnotnull
white-# FROM
white-# pg_class c
white-# JOIN
white-# pg_attribute a ON c.oid = a.attrelid
white-# WHERE
white-# c.relname = 't1'
white-# AND a.attnum > 0
white-# AND NOT a.attisdropped;
attname | atttypid | attlen | attnotnull
---------+----------+--------+------------
id | integer | 4 | f
(1 row)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
查询表的约束信息(结合 pg_constraint)
通过结合 pg_constraint
表查询表的约束信息:
SELECT
conname,
contype,
condeferrable,
condeferred
FROM
pg_constraint
WHERE
conrelid = (SELECT oid FROM pg_class WHERE relname = 't1');
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
实际应用场景
- 元数据查询:通过查询
pg_class
表,可以轻松获取数据库中有关表、索引、视图等的元数据信息,适用于数据审计和元数据管理。 - 统计信息分析:可以结合
relpages
和reltuples
字段,对表的大小和数据量进行估算,为数据库性能调优提供参考数据。 - 权限管理:结合
pg_roles
表,可以分析和管理数据库对象的所有者信息,确保数据库访问权限的合理分配。 - 约束管理:结合
pg_constraint
表,分析和管理表级约束,确保数据完整性。
小结
pg_class
是 PostgreSQL 中用于存储表、索引、视图等关系元数据的重要系统表。通过查询和结合其他系统表,数据库管理员可以获取关于数据库对象的详细信息,进行元数据管理、统计分析、权限管理和约束管理,从而提高数据库管理的效率和安全性。