pg_class
#目录 pg_class
描述了具有列或与表类似的其它对象。这包括索引(但请参阅 pg_index
)、序列(但请参阅 pg_sequence
)、视图、物化视图、复合类型和 TOAST 表;请参阅 relkind
。在下面的描述中,当我们指所有这些类型的对象时,我们称之为“关系”。并非 pg_class
的所有列对于所有关系类型都有意义。
表 52.11. pg_class
列
列 类型 描述 |
---|
行标识符 |
表、索引、视图等的名称。 |
包含此关系的名字空间的 OID。 |
如果存在,则此表行类型对应的数据类型的 OID;对于没有 |
对于类型化表,底层复合类型的 OID;对于所有其他关系,此值为零。 |
关系的属主。 |
访问此表或索引所用的访问方法。如果关系是序列或没有磁盘文件,则此字段无意义;但对于分区表,如果设置了此字段,则在确定分区创建时使用的访问方法时,它会覆盖 |
此关系磁盘文件的名称;零表示这是一个“映射的”关系,其磁盘文件名由底层状态决定。 |
存储此关系的表空间。如果为零,则表示使用数据库的默认表空间。如果关系没有磁盘文件,则此字段无意义;但对于分区表,这是创建分区时使用的表空间(当在创建命令中未指定时)。 |
此表磁盘表示的大小(以页为单位,每页大小为 |
表中的活动行数。这只是规划器使用的估算值。它由 |
表可见性映射中标记为“all-visible”(全部可见)的页数。这只是规划器使用的估算值。它由 |
表可见性映射中标记为“all-frozen”(全部冻结)的页数。这只是用于触发自动 vacuum 的估算值。它也可以与 |
与此表关联的 TOAST 表的 OID,如果没有则为零。TOAST 表将大的属性 “离线” 存储在辅助表中。 |
如果这是一个表并且它有(或最近有过)任何索引,则为真。 |
如果此表在群集的所有数据库之间共享,则为真。只有某些系统目录(如 |
|
|
关系中的用户列数(不包括系统列)。 |
表中 |
如果表有(或曾经有)规则,则为真;请参阅 |
如果表有(或曾经有)触发器,则为真;请参阅 |
如果表或索引有(或曾经有过)任何继承子项或分区,则为真。 |
如果启用了行级安全性,则为真;请参阅 |
如果行级安全性(启用时)也适用于表属主,则为真;请参阅 |
如果关系已填充,则为真(对于除某些物化视图之外的所有关系,此值都为真)。 |
用于为行形成“复制标识”的列: |
如果表或索引是分区,则为真。 |
对于在需要表重写(rewrite)的 DDL 操作期间写入的新关系,此字段包含原始关系的 OID;否则为零。该状态仅在内部可见;对于用户可见的关系,此字段永远不应包含除零以外的任何内容。 |
此表中的所有早于此事务 ID 的事务 ID 都已替换为永久(“已冻结”)事务 ID。这用于跟踪表是否需要 vacuum 以防止事务 ID 回绕或允许 |
此表中的所有早于此多事务 ID 的多事务 ID 都已替换为事务 ID。这用于跟踪表是否需要 vacuum 以防止多事务 ID 回绕或允许 |
访问权限;有关详细信息,请参阅 第 5.8 节 |
访问方法特定的选项,格式为“keyword=value”字符串。 |
如果表是分区(请参阅 |
pg_class
中的几个布尔标志是惰性维护的:如果它们的状态正确,则保证为真,但当条件不再满足时,可能不会立即重置为假。例如,relhasindex
由 CREATE INDEX
设置,但从不被 DROP INDEX
清除。相反,如果 VACUUM
发现表没有索引,它就会清除 relhasindex
。这种安排可以避免竞态条件并提高并发性。
如果您在文档中看到任何不正确、与您在使用特定功能时的经验不符或需要进一步澄清的内容,请使用 此表单 报告文档问题。