pg_class
目录pg_class
描述了具有列或与表类似的其他对象。这包括索引(但请参见pg_index
)、序列(但请参见pg_sequence
)、视图、物化视图、复合类型和TOAST表;请参见relkind
。
在下面,当我们指的是所有这些类型的对象时,我们称之为“关系(relations)”。并非所有pg_class
的列对所有关系类型都有意义。
表 53.11. pg_class
Columns
列类型 描述 |
---|
行标识符 |
表、索引、视图等的名字 |
包含该关系的名字空间的OID |
可能存在的表行类型所对应数据类型的OID;对索引为0,序列,和toast表,索引没有 |
对于有类型的表,为底层组合类型的OID,对于其他所有关系为0 |
关系的拥有者 |
如果这是一个表或者索引,表示索引使用的访问方法(堆、B树、哈希等);否则为0(0出现在序列,以及没有存储的关系,例如视图) |
该关系的磁盘文件的名字,0表示这是一个“映射”关系,其磁盘文件名取决于低层状态 |
存储此关系的表空间。 如果为零,则暗示使用数据库的默认表空间。 如果关系没有磁盘文件,则没有意义, 除了分区表,其中这是在创建命令中未指定时将创建分区的表空间。 |
该表磁盘表示的尺寸,以页面计(页面尺寸为 |
表中的存活行数。这只是一个由规划器使用的估计值。
它被 |
在表的可见性映射表中被标记为全可见的页数。这只是一个由规划器使用的估计值。
它被 |
与该表相关联的TOAST表的OID,如果没有则为零。TOAST表将大属性“线外”存储在一个二级表中。 |
如果这是一个表并且其上建有(或最近建有)索引则为真 |
如果该表在集簇中的所有数据库间共享则为真。只有某些系统目录(如 |
|
|
关系中用户列的数目(系统列不计算在内)。在 |
表上 |
如果表有(或曾有)规则则为真,参见 |
如果表有(或曾有)触发器则为真,参见
|
如果表或索引有(或曾经有过)任何继承子类或分区,则为真 |
如果表上启用了行级安全性则为真,参见
|
如果行级安全性(启用时)也适用于表拥有者则为真,参见
|
如果表已被填充则为真(对于所有关系该列都为真,但对于某些物化视图却不是) |
用来为行形成“replica identity”的列:
|
如果表或索引是一个分区,则为真 |
对于在要求表重写的DDL操作期间被写入的新关系,这个域包含原始关系的OID,否则为零。 那种状态仅在内部可见,对于一个用户可见的关系这个域应该从不包含不是零的值。 |
在此之前的所有事务ID在表中已经被替换为一个永久的(“冻结的”) 事务ID。
这用于跟踪表是否需要被清理,以便阻止事务ID回卷或者允许 |
在此之前的多事务ID在表中已经被替换为一个事务ID。这被用于跟踪表是否需要被清理,以阻止
多事务ID回卷或者允许 |
访问权限,更多信息参见第 5.7 节 |
访问方法相关的选项,以“keyword=value”字符串形式 |
如果表示一个分区(见 |
pg_class
中的一些逻辑标志被以一种懒惰的方式维护:在正确状态时它们被保证为真,但是当条件不再为真时它们并不会被立刻重置为假。
例如,relhasindex
由CREATE INDEX
设置,但它从不会被DROP INDEX
清除。
作为替代,VACUUM
会在找到无索引表后清除其relhasindex
。
这种安排避免了竞争条件并且提高了并发性。