Postgresql系统表
概述
表名称 | 用途 |
---|---|
pg_aggregate | 聚集函数 |
pg_am | 索引访问方法 |
pg_amop | 访问方法操作符 |
pg_amproc | 访问方法支持过程 |
pg_attrdef | 字段缺省值 |
pg_attribute | 表的列(也称为"属性"或"字段") |
pg_authid | 认证标识符(角色) |
pg_auth_members | 认证标识符成员关系 |
pg_autovacuum | 每个关系一个的自动清理配置参数 |
pg_cast | 转换(数据类型转换) |
pg_class | 表、索引、序列、视图(“关系”) |
pg_constraint | 检查约束、唯一约束、主键约束、外键约束 |
pg_conversion | 编码转换信息 |
pg_database | 本集群内的数据库 |
pg_depend | 数据库对象之间的依赖性 |
pg_description | 数据库对象的描述或注释 |
pg_index | 附加的索引信息 |
pg_inherits | 表继承层次 |
pg_language | 用于写函数的语言 |
pg_largeobject | 大对象 |
pg_listener | 异步通知 |
pg_namespace | 模式 |
pg_opclass | 索引访问方法操作符类 |
pg_operator | 操作符 |
pg_pltemplate | 过程语言使用的模板数据 |
pg_proc | 函数和过程 |
pg_rewrite | 查询重写规则 |
pg_shdepend | 在共享对象上的依赖性 |
pg_shdescription | 共享对象上的注释 |
pg_statistic | 优化器统计 |
pg_tablespace | 这个数据库集群里面的表空间 |
pg_trigger | 触发器 |
pg_type | 数据类型 |
pg_aggregate
存储与聚集函数有关的信息。聚集函数是对一个数值集(通常每个匹配查询条件的行中的一个字段)进行操作的函数,它返回从这些值中计算出的一个数值。典型的聚集函数是 sum, count, max 。pg_aggregate 里的每条记录都是一条 pg_proc 里面的记录的扩展。pg_proc 记录承载该聚集的名字、输入和输出数据类型,以及其它一些和普通函数类似的信息。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
aggfnoid | regproc | pg_proc.oid | 此聚集函数的pg_proc OID |
aggtransfn | regproc | pg_proc.oid | 转换函数 |
aggfinalfn | regproc | pg_proc.oid | 最终处理函数(如果没有则为零) |
aggsortop | oid | pg_operator.oid | 关联排序操作符(零或者无) |
aggtranstype | oid | pg_type.oid | 此聚集函数的内部转换(状态)数据的数据类型 |
agginitval | text | 转换状态的初始值。这是一个文本数据域,它包含初始值的外部字符串表现形式。如果数据域是NULL,那么转换状态值从NULL开始。 |
pg_am
pg_am 存储有关索引访问方法的信息。系统支持的每种索引访问方法都有一行。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
amname | name | 访问方法的名字 | |
amstrategies | int2 | 这个访问方法的操作符策略个数 | |
amsupport | int2 | 这个访问方法的支持过程个数 | |
amorderstrategy | int2 | 如果索引不提供排序顺序则为零,否则就是描述排序顺序的策略操作符个数 | |
amcanunique | bool | 这种访问方式是否支持唯一索引? | |
amcanmulticol | bool | 这种访问方式是否支持多字段索引? | |
amoptionalkey | bool | 这个访问访法支持在一个索引字段上没有任何约束的扫描吗? | |
amindexnulls | bool | 这种访问方式是否支持 NULL 索引记录? | |
amstorage | bool | 允许索引存储的数据类型与列的数据类型不同? | |
amclusterable | bool | 允许在一个这种类型的索引上群集? | |
aminsert | regproc | pg_proc.oid | "插入这个行"函数 |
ambeginscan | regproc | pg_proc.oid | "开始新扫描"函数 |
amgettuple | regproc | pg_proc.oid | "下一个有效行"函数 |
amgetmulti | regproc | pg_proc.oid | "抓取多个行"函数 |
amrescan | regproc | pg_proc.oid | "重新开始这个扫描"函数 |
amendscan | regproc | pg_proc.oid | "结束这次扫描"函数 |
ammarkpos | regproc | pg_proc.oid | "标记当前扫描位置"函数 |
amrestrpos | regproc | pg_proc.oid | "恢复已标记的扫描位置"函数 |
ambuild | regproc | pg_proc.oid | "建立新索引"函数 |
ambulkdelete | regproc | pg_proc.oid | 批量删除函数 |
amvacuumcleanup | regproc | pg_proc.oid | VACUUM 后的清理函数 |
amcostestimate | regproc | pg_proc.oid | 估计一个索引扫描开销的函数 |
amoptions | regproc | pg_proc.oid | 为一个索引分析和确认 reloptions 的函数 |
pg_amop
pg_amop 表存储有关和索引访问方法操作符类关联的信息。如果一个操作符是一个操作符类中的成员,那么在这个表中会占据一行。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
amopclaid | oid | pg_opclass.oid | 这条记录表示的索引操作符类 |
amopsubtype | oid | pg_type.oid | 区分一个策略的多条记录的子类型,缺省为零 |
amopstrategy | int2 | 操作符策略数 | |
amopreqcheck | bool | 索引命中必须重新检查 | |
amopopr | oid | pg_operator.oid | 该操作符的 OID |
pg_amproc
pg_amproc 存储有关与索引访问方法操作符类相关联的支持过程的信息。每个属于某个操作符类的支持过程都占有一行。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
amopclaid | oid | pg_opclass.oid | 使用这条记录的索引操作符类 |
amprocsubtype | oid | pg_type.oid | 如果是跨类型的过程,就是子类型,否则就是零 |
amprocnum | int2 | 支持过程编号 | |
amproc | regproc | pg_proc.oid | 过程的 OID |
pg_attrdef
pg_attrdef 表存储字段缺省值。字段的主要信息存放在 pg_attribute。只有明确声明一个缺省值(该表何时创建或字段何时增加)的字段在这里有行。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
adrelid | oid | pg_class.oid | 这个字段所属的表 |
adnum | int2 | pg_attribute.attnum | 字段数目 |
adbin | text | 字段缺省值的内部表现形式 | |
adsrc | text | 人类可读的缺省值的内部表现形式 |
adsrc 是历史遗留,最好不要使用它,因为它并未跟踪可能影响缺省值表现形式的外部变化。反编译 adbin 字段(比如,用 pg_get_expr)是更好的显示缺省值的方法。
pg_attribute
pg_attribute 表存储关于表的字段的信息。数据库里每个表的每个字段都在 pg_attribute 里有一行。还有用于索引,以及所有在 pg_class 里有记录的对象。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
attrelid | oid | pg_class.oid | 此字段所属的表 |
attname | name | 字段名字 | |
atttypid | oid | pg_type.oid | 这个字段的数据类型 |
attstattarget | int4 | 控制 ANALYZE 为这个字段积累的统计细节的级别。零值表示不收集统计信息。负数表示使用系统缺省的统计对象。正数值的确切信息是和数据类型相关的。对于标量数据类型,attstattarget 既是要收集的"最常用数值"的目标数目,也是要创建的柱状图的目标数量。 | |
attlen | int2 | 是本字段类型的 pg_type.typlen 的拷贝 | |
attnum | int2 | 字段数目。普通字段是从 1 开始计数的。系统字段(比如 oid)有(任意)正数。 | |
attndims | int4 | 如果该字段是数组,那么是维数,否则是 0 。目前,一个数组的维数并未强制,因此任何非零值都表示"这是一个数组"。 | |
attcacheoff | int4 | 在磁盘上的时候总是 -1 ,但是如果加载入内存中的行描述器中,它可能会被更新以缓冲在行中字段的偏移量。 | |
atttypmod | int4 | 记录创建新表时支持的类型特定的数据(比如一个 varchar 字段的最大长度)。它传递给类型相关的输入和长度转换函数当做第三个参数。其值对那些不需要 atttypmod 的类型通常为 -1 。 | |
attbyval | bool | 这个字段类型的 pg_type.typbyval 的拷贝。 | |
attstorage | char | 这个字段的类型的 pg_type.typstorage 的拷贝。对于可压缩的数据类型(TOAST),这个字段可以在字段创建之后改变,以便于控制存储策略。 | |
attalign | char | 这个字段类型的 pg_type.typalign 的拷贝 | |
attnotnull | bool | 这代表一个非空约束。可以改变这个字段以打开或者关闭这个约束。 | |
atthasdef | bool | 这个字段有一个缺省值,此时它对应 pg_attrdef 表里实际定义此值的记录。 | |
attisdropped | bool | 这个字段已经被删除了,不再有效。一个已经删除的字段物理上仍然存在表中,但会被分析器忽略,因此不能再通过 SQL 访问。 | |
attislocal | bool | 这个字段是局部定义在关系中的。请注意一个字段可以同时是局部定义和继承的。 | |
attinhcount | int4 | 这个字段所拥有的直接祖先的个数。如果一个字段的祖先个数非零,那么它就不能被删除或重命名。 |
在一个已被删除字段的 pg_attribute 记录里,atttypid 将被重置为零,但是 attlen 和其它从 pg_type 拷贝的仍然有效。这么安排是为了对付后来被删除的字段的数据类型也被删除的情况,因为这个时候不再有 pg_type 行了。attlen 和其它字段可以用于解析表中一行内容。
pg_authid
pg_authid 包含有关数据库认证标识符(角色)的信息。一个角色体现"用户"和"组"的概念。一个用户实际上只是一个设置了 rolcanlogin 标志的角色。任何角色(不管设置了 rolcanlogin)标志)都可以有其它角色做为成员;参阅 pg_auth_members
因为这个系统表包含口令,所以它不是公共可读的。pg_roles 是一个在 pg_authid 上的视图,只是把口令域填成了空白。
因为用户标识是集群范围的,pg_authid 在一个集群里所有的数据库之间是共享的:每个集群只有一个 pg_authid 拷贝,而不是每个数据库一个。
名字 | 类型 | 描述 |
---|---|---|
rolname | name | 角色名称 |
rolsuper | bool | 角色拥有超级用户权限 |
rolinherit | bool | 角色自动继承其所属角色的权限 |
rolcreaterole | bool | 角色可以创建更多角色 |
rolcreatedb | bool | 角色可以创建数据库 |
rolcatupdate | bool | 角色可以直接更新系统表。如果没有设置这个字段为真,即使超级用户也不能这么做。 |
rolcanlogin | bool | 角色可以登录,也就是说,这个角色可以给予会话认证标识符。 |
rolconnlimit | int4 | 对于可以登录的角色,限制其最大并发连接数量。-1 表示没有限制。 |
rolpassword | text | 口令(可能是加密的);如果没有则为 NULL |
rolvaliduntil | timestamptz | 口令失效时间(只用于口令认证);如果没有失效期,则为 NULL |
rolconfig | text[] | 运行时配置变量的会话缺省 |
pg_auth_members
pg_auth_members 显示角色之间的成员关系。任何非闭环的关系集合都是允许的。
因为用户标识是集群范围的,pg_auth_members 是在一个集群里的所有数据库之间共享的:每个集群里只有一个 pg_auth_members 拷贝,而不是每个数据库一个。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
roleid | oid | pg_authid.oid | 拥有有成员的角色的 ID |
member | oid | pg_authid.oid | 属于 roleid 角色的一个成员的角色的 ID |
grantor | oid | pg_authid.oid | 赋予此成员关系的角色的 ID |
admin_option | bool | 如果 member 可以把 roleid 角色的成员关系赋予其它角色,则为真。 |
pg_autovacuum
pg_autovacuum 为 autovacuum 守护进程存储针对每个关系的配置参数,给出的参数将用于自动清理该表。如果没有提供条目,那么使用系统范围的缺省。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
vacrelid | oid | pg_class.oid | 此条记录用于的表 |
enabled | bool | 如果为假,该表从不会被自动清理 | |
vac_base_thresh | integer | 清理前修改的最少的行数目 | |
vac_scale_factor | float4 | 追加到 vac_base_thresh 上的行的倍数 | |
anl_base_thresh | integer | 分析之前修改的最少的行数目 | |
anl_scale_factor | float4 | 追加到 anl_base_thresh 上的行的倍数 | |
vac_cost_delay | integer | 自定义的 vacuum_cost_delay 参数 | |
vac_cost_limit | integer | 自定义的 vacuum_cost_limit 参数 | |
freeze_min_age | integer | 自定义的 vacuum_freeze_min_age 参数 | |
freeze_max_age | integer | 自定义的 autovacuum_freeze_max_age 参数 |
pg_cast
pg_cast 表存储数据类型转换路径,包括内置路径和那些通过 CREATE CAST 定义的路径。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
castsource | oid | pg_type.oid | 源数据类型的 OID |
casttarget | oid | pg_type.oid | 目标数据类型的 OID |
castfunc | oid | pg_proc.oid | 用于执行这个转换的函数的 OID 。如果该数据类型是二进制兼容的,那么为零(也就是说,不需要运行时的操作来执行转换)。 |
castcontext | char | 标识这个转换可以在什么环境里调用。e 表示只能进行明确的转换(使用 CAST 或 :: 语法)。a 表示在赋值给目标字段的时候隐含调用,也可以明确调用。i 表示在表达式中隐含,当然也包括其它情况。 |
在 pg_cast 里列出的类型转换函数必须总是以类型转换的源类型作为它的第一个参数类型,并且返回类型转换的目的类型作为它的结果类型。一个类型转换函数最多有三个参数。如果出现了第二个参数,必须是 integer 类型;它接受与目标类型关联的修饰词,如果没有,就是 -1 。如果出现了第三个参数,那么必须是 boolean 类型;如果该类型转换是一种明确的转换,那么它接受 true ,否则接受 false 。
在 pg_cast 里创建一条源类型和目标类型相同的记录是合理的,只要相关联的函数接受多过一个参数。这样的记录代表"长度转换函数",他们把该类型的数值转换为对特定的类型修饰词数值合法的值。不过,请注意,现在还不支持将非缺省类型修饰词和用户创建数据类型关联起来,因此这个设施只用于少量的内置类型,这些类型都有内置于语法分析器里的类型修饰词语法。
如果一条 pg_cast 记录有着不同的原类型和目标类型,并且有一个接收多于一个参数的函数,那么它就意味着用一个步骤从一种类型转换到另外一种类型,同时还附加一个长度转换。如果没有这样的记录,那么转换成一个使用了类型修饰词的类型涉及两个步骤,一个是在数据类型之间转换,另外一个是附加修饰词。
pg_class
pg_class 表记载表和几乎所有有字段或者是那些类似表的东西。包括索引(不过还要参阅 pg_index)、序列、视图、复合类型和一些特殊关系类型;参阅 relkind 。在下面,当指所有这些对象的时候说"关系"(relations)。不是所有字段对所有关系类型都有意义。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
relname | name | 表、索引、视图等的名字。 | |
relnamespace | oid | pg_namespace.oid | 包含这个关系的名字空间(模式)的 OID |
reltype | oid | pg_type.oid | 对应这个表的行类型的数据类型(索引为零,它们没有 pg_type 记录)。 |
relowner | oid | pg_authid.oid | 关系所有者 |
relam | oid | pg_am.oid | 如果行是索引,那么就是所用的访问模式(B-tree, hash 等等) |
relfilenode | oid | 这个关系在磁盘上的文件的名字,如果没有则为 0 | |
reltablespace | oid | pg_tablespace.oid | 这个关系存储所在的表空间。如果为零,则意味着使用该数据库的缺省表空间。如果关系在磁盘上没有文件,则这个字段没有什么意义。 |
relpages | int4 | 以页(大小为 BLCKSZ)的此表在磁盘上的形式的大小。它只是规划器用的一个近似值,是由 VACUUM, ANALYZE 和几个 DDL 命令,比如 CREATE INDEX 更新。 | |
reltuples | float4 | 表中行的数目。只是规划器使用的一个估计值,由 VACUUM, ANALYZE 和几个 DDL 命令,比如 CREATE INDEX 更新。 | |
reltoastrelid | oid | pg_class.oid | 与此表关联的 TOAST 表的 OID ,如果没有为 0 。TOAST 表在一个从属表里"离线"存储大字段。 |
reltoastidxid | oid | pg_class.oid | 对于 TOAST 表是它的索引的 OID ,如果不是 TOAST 表则为 0 |
relhasindex | bool | 如果它是一个表而且至少有(或者最近有过)一个索引,则为真。它是由 CREATE INDEX 设置的,但 DROP INDEX 不会立即将它清除。如果 VACUUM 现一个表没有索引,那么它将清理 relhasindex 。 | |
relisshared | bool | 如果该表在整个集群中由所有数据库共享则为真。只有某些系统表(比如 pg_database)是共享的。 | |
relkind | char | r = 普通表, i = 索引, S = 序列, v = 视图, c = 复合类型, t = TOAST 表 | |
relnatts | int2 | 关系中用户字段数目(除了系统字段以外)。在 pg_attribute 里肯定有相同数目对应行。又见 pg_attribute.attnum | |
relchecks | int2 | 表里的检查约束的数目;参阅 pg_constraint 表 | |
reltriggers | int2 | 表里的触发器的数目;参阅 pg_trigger 表 | |
relukeys | int2 | 未使用(不是唯一值的数目) | |
relfkeys | int2 | 未使用(不是表中外键的数目) | |
relrefs | int2 | 未使用 | |
relhasoids | bool | 如果为关系中每行都生成一个 OID 则为真 | |
relhaspkey | bool | 如果这个表有一个(或者曾经有一个)主键,则为真。 | |
relhasrules | bool | 如表有规则就为真;参阅 pg_rewrite 表 | |
relhassubclass | bool | 如果有(或者曾经有)任何继承的子表,为真。 | |
relfrozenxid | xid | 该表中所有在这个之前的事务 ID 已经被一个固定的(“frozen”)事务 ID 替换。这用于跟踪该表是否需要为了防止事务 ID 重叠或者允许收缩 pg_clog 而进行清理。如果该关系不是表则为零(InvalidTransactionId)。 | |
relacl | aclitem[] | 访问权限。参阅 GRANT 和 REVOKE 获取详细信息。 | |
reloptions | text[] | 访问方法特定的选项,使用"keyword=value"格式的字符串 |
pg_constraint
pg_constraint 存储表上的检查约束、主键、唯一约束和外键约束。字段约束不会得到特殊对待。每个字段约束都等效于某些表约束。非空约束记录在 pg_attribute 表中。
在域上面的检查约束也存储在这里。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
conname | name | 约束名字(不一定是唯一的) | |
connamespace | oid | pg_namespace.oid | 包含这个约束的名字空间的 OID |
contype | char | c = 检查约束, f = 外键约束, p = 主键约束, u = 唯一约束 | |
condeferrable | bool | 这个约束可以推迟吗? | |
condeferred | bool | 缺省时这个约束是否推迟的? | |
conrelid | oid | pg_class.oid | 这个约束所在的表;如果不是表约束则为 0 |
contypid | oid | pg_type.oid | 这个约束所在的域;如果不是一个域约束则为 0 |
confrelid | oid | pg_class.oid | 如果是外键,则为参考的表;否则为 0 |
confupdtype | char | 外键更新动作代码 | |
confdeltype | char | 外键删除动作代码 | |
confmatchtype | char | 外键匹配类型 | |
conkey | int2[] | pg_attribute.attnum | 如果是表约束,则是约束控制的字段列表 |
confkey | int2[] | pg_attribute.attnum | 如果是一个外键,是参考的字段的列表 |
conbin | text | 如果是检查约束,那就是其表达式的内部形式 | |
consrc | text | 如果是检查约束,则是表达式的人类可读形式 |
【注意】 consrc 在被引用的对象改变之后不会被更新,它不会跟踪字段的名字修改。与其依赖这个字段,最好还是使用 pg_get_constraintdef() 来抽取一个检查约束的定义。
【注意】 pg_class.relchecks 需要和在此表上为给定关系找到的检查约束的数目一致。
pg_conversion
pg_conversion 描述可用的编码转换信息。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
conname | name | 转换名字(在一个名字空间里是唯一的) | |
connamespace | oid | pg_namespace.oid | 包含这个转换的名字空间的 OID |
conowner | oid | pg_authid.oid | 编码转换的属主 |
conforencoding | int4 | 源编码 ID | |
contoencoding | int4 | 目的编码 ID | |
conproc | regproc | pg_proc.oid | 转换过程 |
condefault | bool | 如果这是缺省转换则为真 |
pg_database
pg_database 表存储关于可用数据库的信息。和大多数系统表不同,pg_database 是在一个集群里的所有数据库共享的:每个集群只有一份 pg_database 拷贝,而不是每个数据库一份。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
datname | name | 数据库名字 | |
datdba | oid | pg_authid.oid | 数据库所有人,通常为其创建者 |
encoding | int4 | 数据库的字符编码方式(pg_encoding_to_char() 能够将这个数字转换为相应的编码名称) | |
datistemplate | bool | 如果为真则此数据库可以用于 CREATE DATABASE 的 TEMPLATE 子句,把新数据库创建为此数据库的克隆。 | |
datallowconn | bool | 如果为假则没有人可以连接到这个数据库。这个字段用于保护 template0 数据库不被更改。 | |
datconnlimit | int4 | 设置该数据库上允许的最大并发连接数,-1 表示无限制。 | |
datlastsysoid | oid | 数据库里最后一个系统 OID ;对 pg_dump 特别有用。 | |
datfrozenxid | xid | 该数据库中中所有在这个之前的事务 ID 已经被一个固定的(“frozen”)事务 ID 替换。这用于跟踪该数据库是否需要为了防止事务 ID 重叠或者允许收缩 pg_clog 而进行清理。它是针对每个表的 pg_class.relfrozenxid 中的最小值。 | |
dattablespace | oid | pg_tablespace.oid | 该数据库的缺省表空间。在这个数据库里,所有 pg_class.reltablespace 为零的表都将保存在这个表空间里;特别要指出的是,所有非共享的系统表也都存放在这里。 |
datconfig | text[] | 运行时配置变量的会话缺省值 | |
datacl | aclitem[] | 访问权限。 |
pg_depend
pg_depend 表记录数据库对象之间的依赖关系。这个信息允许 DROP 命令找出哪些其它对象必须由 DROP CASCADE 删除,或者是在 DROP RESTRICT 的情况下避免删除。
这个表的功能类似 pg_shdepend ,用于记录那些在数据库集群之间共享的对象之间的依赖性关系。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
classid | oid | pg_class.oid | 有倚赖对象所在系统表的 OID |
objid | oid | 任何 OID 属性 | 指定的有依赖对象的 OID |
objsubid | int4 | 对于表字段,这个是该属性的字段数(objid 和 classid 引用表本身)。对于所有其它对象类型,目前这个字段是零。 | |
refclassid | oid | pg_class.oid | 被引用对象所在的系统表的 OID |
refobjid | oid | 任意 OID 属性 | 指定的被引用对象的 OID |
refobjsubid | int4 | 对于表字段,这个是该字段的字段号(refobjid 和 refclassid 引用表本身)。对于所有其它对象类型,目前这个字段是零。 | |
deptype | char | 一个定义这个依赖关系特定语义的代码。 |
在所有情况下,一个 pg_depend 记录表示被引用的对象不能在有依赖的对象被删除前删除。不过,这里还有几种由 deptype 定义的情况:
-
DEPENDENCY_NORMAL (n)
独立创建的对象之间的一般关系。有倚赖的对象可以在不影响被引用对象的情况下删除。被引用对象只有在声明了 CASCADE 的情况下删除,这时有依赖的对象也被删除。例子:一个表字段对其数据类型有一般依赖关系。
-
DEPENDENCY_AUTO (a)
有依赖对象可以和被引用对象分别删除,并且如果删除了被引用对象则应该被自动删除(不管是 RESTRICT 或 CASCADE 模式)。例子:一个表上面的命名约束是在该表上的自动依赖关系,因此如果删除了表,它也会被删除。
-
DEPENDENCY_INTERNAL (i)
有依赖的对象是作为被引用对象的一部分创建的,实际上只是它的内部实现的一部分。DROP 有依赖对象是不能直接允许的(将告诉用户发出一条删除被引用对象的 DROP)。一个对被引用对象的 DROP 将传播到有依赖对象,不管是否声明了 CASCADE 。例子:一个创建来强制外键约束的触发器在该约束的 pg_constraint 记录上是标记为内部依赖的。
-
DEPENDENCY_PIN §
没有有依赖对象;这种类型的记录标志着系统本身依赖于被引用对象,因此这个对象决不能被删除。这种类型的记录只有在 initdb 的时候创建。有依赖对象的字段里是零。
将来可能还会有其它依赖的风格。
pg_description
pg_description 表可以给每个数据库对象存储一个可选的描述(注释)。你可以用 COMMENT 命令操作这些描述,并且可以用 psql 的 \d 命令查看。许多内置的系统对象的描述提供了 pg_description 的初始内容。
pg_shdescription 提供了类似的功能,它记录了整个集群范围内共享对象的注释。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
objoid | oid | 任意 oid 属性 | 这条描述所描述的对象的 OID |
classoid | oid | pg_class.oid | 这个对象出现的系统表的 OID |
objsubid | int4 | 对于一个表字段的注释,它是字段号(objoid 和 classoid 指向表自身)。对于其它对象类型,它是零。 | |
description | text | 作为对该对象的描述的任意文本 |
pg_index
pg_index 包含关于索引的一部分信息。其它的信息大多数在 pg_class。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
indexrelid | oid | pg_class.oid | 这个索引在 pg_class 里的记录的 OID |
indrelid | oid | pg_class.oid | 使用这个索引的表在 pg_class 里的记录的 OID |
indnatts | int2 | 索引中的字段数目(复制的 pg_class.relnatts) | |
indisunique | bool | 如果为真,这是个唯一索引 | |
indisprimary | bool | 如果为真,该索引代表该表的主键。这个字段为真的时候 indisunique 应该总是为真。 | |
indisclustered | bool | 如果为真,那么该表最后在这个索引上建了簇。 | |
indisvalid | bool | 如果为真,那么该索引可以用于查询。如果为假,那么该索引可能不完整,仍然必须在 INSERT/UPDATE 操作时进行更新,不过不能安全的用于查询。如果是唯一索引,那么唯一属性也将不为真。 | |
indkey | int2vector | pg_attribute.attnum | 这是一个包含 indnatts 值的数组,这些数组值表示这个索引所建立的表字段。比如一个值为 1 3 的意思是第一个字段和第三个字段组成这个索引键字。这个数组里的零表明对应的索引属性是在这个表字段上的一个表达式,而不是一个简单的字段引用。 |
indclass | oidvector | pg_opclass.oid | 对于索引键字里面的每个字段,这个字段都包含一个指向所使用的操作符类的 OID ,参阅 pg_opclass 获取细节。 |
indexprs | text | 表达式树(以 nodeToString() 形式表现)用于那些非简单字段引用的索引属性。它是一个列表,在 indkey 里面的每个零条目一个元素。如果所有索引属性都是简单的引用,则为空。 | |
indpred | text | 部分索引断言的表达式树(以 nodeToString() 的形式表现)。如果不是部分索引,则是空字符串。 |
pg_inherits
pg_inherits 记录关于表继承层次的信息。数据库里每个直接的子系表都有一条记录。间接的继承可以通过追溯记录链来判断。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
inhrelid | oid | pg_class.oid | 子表的 OID |
inhparent | oid | pg_class.oid | 父表的 OID |
inhseqno | int4 | 如果一个子表存在多个直系父表(多重继承),这个数字表明此继承字段的排列顺序。计数从 1 开始。 |
pg_language
pg_language 登记编程语言,你可以用这些语言或接口写函数或者存储过程。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
lanname | name | 语言的名字 | |
lanispl | bool | 对于内部语言而言是假(比如 SQL),对于用户定义的语言则是真。目前,pg_dump 仍然使用这个东西判断哪种语言需要转储,但是这些可能在将来被其它机制取代。 | |
lanpltrusted | bool | 如果这是可信语言则为真,意味着系统相信它不会被授予任何正常 SQL 执行环境之外的权限。只有超级用户可以创建不可信的语言。 | |
lanplcallfoid | oid | pg_proc.oid | 对于非内部语言,这是指向该语言处理器的引用,语言处理器是一个特殊函数,负责执行以某种语言写的所有函数。 |
lanvalidator | oid | pg_proc.oid | 这个字段引用一个语言校验器函数,它负责检查新创建的函数的语法和有效性。如果没有提供校验器,则为零。 |
lanacl | aclitem[] | 访问权限。 |
pg_largeobject
pg_largeobject 表保存那些标记着"大对象"的数据。一个大对象是使用其创建时分配的 OID 标识的。每个大对象都分解成足够小的小段或者"页面"以便以行的形式存储在 pg_largeobject 里。每页的数据定义为 LOBLKSIZE(目前是 BLCKSZ/4 或者通常是 2K 字节)。
名字 | 类型 | 描述 |
---|---|---|
loid | oid | 包含本页的大对象的标识符 |
pageno | int4 | 本页在其大对象数据中的页码从零开始计算 |
data | bytea | 存储在大对象中的实际数据。这些数据绝不会超过 LOBLKSIZE 字节,而且可能更少。 |
pg_listener
pg_listener 表支持LISTEN命令。一个监听器为它监听的每个通知名称在 pg_listener 里创建一条记录。一个通知发起人扫描 pg_listener 并且更新每条匹配的记录以显示一个通知已经发生。通知发起人还发送一个信号给监听器(使用记录在表中的 PID)以唤醒它做处理。
名字 | 类型 | 描述 |
---|---|---|
relname | name | 通知条件名。该名字不需要匹配任何数据库中的实际关系;项 relname 是历史原因形成的。 |
listenerpid | int4 | 创建此条目的服务器进程的 PID |
notification | int4 | 如果这个监听器上没有等待的事件,那么是零。如果有等待的事件,那么是发送通知的服务器的 PID |
pg_namespace
pg_namespace 存储名字空间。名字空间是 SQL 模式下层的结构:每个名字空间有独立的关系,类型等集合但并不会相互冲突。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
nspname | name | 名字空间的名字 | |
nspowner | oid | pg_authid.oid | 名字空间的所有者 |
nspacl | aclitem[] | 访问权限 |
pg_opclass
pg_opclass 定义索引访问方法操作符类。每个操作符类为一种特定数据类型和一种特定索引访问方法定义索引字段的语义。请注意对于一种指定的数据类型/访问方法组合,可能会有多种操作符类,这样就可以支持多种行为。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
opcamid | oid | pg_am.oid | 操作符类所服务的索引访问方法 |
opcname | name | 这个操作符类的名字 | |
opcnamespace | oid | pg_namespace.oid | 这个操作符类的名字空间 |
opcowner | oid | pg_authid.oid | 操作符类属主 |
opcintype | oid | pg_type.oid | 操作符类的输入数据类型 |
opcdefault | bool | 如果操作符类是 opcintype 的缺省,则为真 | |
opckeytype | oid | pg_type.oid | 索引数据的类型,如果和 opcintype 相同则为零 |
pg_operator
pg_operator 存储有关操作符的信息。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
oprname | name | 操作符的名字 | |
oprnamespace | oid | pg_namespace.oid | 包含此操作符的名字空间的 OID |
oprowner | oid | pg_authid.oid | 操作符所有者 |
oprkind | char | b = 中缀(“两边”), l = 前缀(“左边”), r = 后缀(“右边”) | |
oprcanhash | bool | 这个操作符支持 Hash 连接 | |
oprleft | oid | pg_type.oid | 左操作数的类型 |
oprright | oid | pg_type.oid | 右操作数的类型 |
oprresult | oid | pg_type.oid | 结果类型 |
oprcom | oid | pg_operator.oid | 此操作符的交换符,如果存在的话 |
oprnegate | oid | pg_operator.oid | 此操作符的反转器,如果存在的话 |
oprlsortop | oid | pg_operator.oid | 如果此操作符支持融合连接,这里是对左操作数排序的操作符(L<L) |
oprrsortop | oid | pg_operator.oid | 如果此操作符支持融合连接,这里是对右操作数排序的操作符(R<R) |
oprltcmpop | oid | pg_operator.oid | 如果这个操作符支持融合连接,那么这是比较左右操作数类型(L<R)的小于操作符 |
oprgtcmpop | oid | pg_operator.oid | 如果这个操作符支持融合连接,那么这是比较左右操作数类型(L>R)的大于操作符 |
oprcode | regproc | pg_proc.oid | 实现这个操作符的函数 |
oprrest | regproc | pg_proc.oid | 此操作符的约束选择性计算函数 |
oprjoin | regproc | pg_proc.oid | 此操作符的连接选择性计算函数 |
pg_pltemplate
pg_pltemplate 为过程语言存储"模板"信息。一个语言的模板允许该语言可以在某个数据库里使用简单的 CREATE LANGUAGE 命令创建,而不需要声明实现细节。
和许多系统表不一样,pg_pltemplate 是在集群里的所有数据库之间共享的:每个集群只有一个 pg_pltemplate 的拷贝,而不是每个数据库一个。这样就允许这些信息在需要时每个数据库都可以访问。
名字 | 类型 | 描述 |
---|---|---|
tmplname | name | 这个模板所应用的语言的名字 |
tmpltrusted | boolean | 如果语言被认为是可信的,则为真 |
tmplhandler | text | 调用处理器函数的名字 |
tmplvalidator | text | 校验函数的名字,如果没有则为 NULL |
tmpllibrary | text | 实现语言的共享库的路径 |
tmplacl | aclitem[] | 模板的访问权限(未使用) |
目前还没有任何命令可以用于操作过程语言模板;要修改内置的信息,超级用户必须使用普通的 INSERT, DELETE, UPDATE 命令修改该表。将来版本的 PostgreSQL 有可能提供一些命令来修改这些内容,以便更清晰些。
在实现的时候,tmplacl 字段将提供对模板自身的访问控制(也就是使用它创建一个语言的权限),而不是对那些从模板创建的语言的访问控制。
pg_proc
pg_proc 表存储关于函数(或过程)的信息。该表包含聚集函数和普通函数的数据。如果 proisagg 为真,那么在 pg_aggregate 里应该有一个匹配行。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
proname | name | 函数名字 | |
pronamespace | oid | pg_namespace.oid | 包含该函数名字空间的 OID |
proowner | oid | pg_authid.oid | 函数的所有者 |
prolang | oid | pg_language.oid | 这个函数的实现语言或调用接口 |
proisagg | bool | 函数是聚集函数 | |
prosecdef | bool | 函数是一个安全定义器(也就是一个"setuid"函数) | |
proisstrict | bool | 如果任何调用参数是空,那么函数返回空。这时函数实际上连调用都不调用。不是"strict"的函数必须准备处理空输入。 | |
proretset | bool | 函数返回一个集合(也就是说,指定数据类型的多个数值) | |
provolatile | char | 告诉该函数的结果是否只倚赖于它的输入参数,或者还会被外接因素影响。对于"不可变的"(immutable)函数它是 i ,这样的函数对于相同的输入总是产生相同的结果。对于"稳定的"(stable)函数它是 s ,(对于固定输入)其结果在一次扫描里不变。对于"易变"(volatile)函数它是 v ,其结果可能在任何时候变化。v 也用于那些有副作用的函数,因此调用它们无法得到优化。 | |
pronargs | int2 | 参数数目 | |
prorettype | oid | pg_type.oid | 返回值的数据类型 |
proargtypes | oidvector | pg_type.oid | 一个存放函数参数的数据类型的数组。数组里只包括输入参数(包括 INOUT 参数),因此代表该函数的调用签名(接口)。 |
proallargtypes | oid[] | pg_type.oid | 一个包含函数参数的数据类型的数组。数组里包括所有参数的类型(包括 OUT 和 INOUT 参数);不过,如果所有参数都是 IN 参数,那么这个字段就会是空。请注意数组下标是以 1 为起点的,而因为历史原因,proargtypes 的下标起点为 0 。 |
proargmodes | char[] | 一个保存函数参数模式的数组,编码如下:i 表示 IN 参数, o 表示 OUT 参数, b 表示 INOUT 参数。如果所有参数都是 IN 参数,那么这个字段为空。请注意,下标对应的是 proallargtypes 的位置,而不是 proargtypes | |
proargnames | text[] | 一个保存函数参数的名字的数组。没有名字的参数在数组里设置为空字符串。如果没有一个参数有名字,这个字段将是空。请注意,此数组的下标对应 proallargtypes 而不是 proargtypes | |
prosrc | text | 这个字段告诉函数处理器如何调用该函数。它实际上对于解释语言来说就是函数的源程序,或者一个链接符号,一个文件名,或者是任何其它的东西,具体取决于语言/调用习惯的实现。 | |
probin | bytea | 关于如何调用该函数的附加信息。同样,其含义也是和语言相关的。 | |
proacl | aclitem[] | 访问权限 |
pg_rewrite
pg_rewrite 存储为表和视图定义的重写规则。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
rulename | name | 规则名称 | |
ev_class | oid | pg_class.oid | 使用这条规则的表名称 |
ev_attr | int2 | 这条规则适用的字段(目前总是为零,表示整个表) | |
ev_type | char | 规则适用的事件类型: 1 = SELECT, 2 = UPDATE, 3 = INSERT, 4 = DELETE | |
is_instead | bool | 如果该规则是 INSTEAD 规则,那么为真 | |
ev_qual | text | 规则的资格条件的表达式树(以 nodeToString() 形式存在) | |
ev_action | text | 规则动作的查询树(以 nodeToString() 形式存在) |
**【注意】**如果一个表在这个系统表里有任何规则存在,那么 pg_class.relhasrules 必须为真。
pg_shdepend
pg_shdepend 记录数据库对象和共享对象(比如角色)之间的依赖性关系。这些信息允许 PostgreSQL 保证在企图删除这些对象之前,这些对象是没有被引用的。
pg_depend表的作用类似,只是它是用于在一个数据库内部的对象的依赖性关系的。
和其它大多数系统表不同,pg_shdepend 是在集群里面所有的数据库之间共享的:每个数据库集群只有一个 pg_shdepend ,而不是每个数据库一个。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
dbid | oid | pg_database.oid | 依赖对象所在的数据库的 OID ,如果是共享对象,则为零 |
classid | oid | pg_class.oid | 依赖对象所在的系统表的 OID |
objid | oid | 任意 oid 属性 | 指定的依赖对象的 OID |
refclassid | oid | pg_class.oid | 被引用对象所在的系统表的 OID(必须是一个共享表) |
refobjid | oid | 任意 oid 属性 | 指定的被引用对象的 OID |
deptype | char | 一段代码,定义了这个依赖性关系的特定语义 |
在任何情况下,一条 pg_shdepend 记录就表面这个被引用的对象不能在未删除依赖对象的前提下删除。不过,deptype 同时还标出了几种不同的子风格:
-
SHARED_DEPENDENCY_OWNER (o)
被引用的对象(必须是一个角色)是依赖对象的所有者。
-
SHARED_DEPENDENCY_ACL (a)
被引用的对象(必须是一个角色)在依赖对象的 ACL(访问控制列表,也就是权限列表)里提到。SHARED_DEPENDENCY_ACL 不会在对象的所有者头上添加的,因为所有者会有一个 SHARED_DEPENDENCY_OWNER 记录。
-
SHARED_DEPENDENCY_PIN §
没有依赖对象;这类记录标识系统自身依赖于该被依赖对象,因此这样的对象绝对不能被删除。这种类型的记录只是由 initdb 创建。这样的依赖对象的字段都是零。
其它依赖性的风格可能在将来会出现。请注意,目前的定义只是支持把角色当作被引用对象。
pg_shdescription
pg_shdescription 为共享数据库对象存储可选的注释。
pg_description提供了类似的功能,它记录了单个数据库中对象的注释。
不同于大多数系统表,pg_shdescription 是在集群里面所有的数据库之间共享的:每个数据库集群只有一个 pg_shdescription ,而不是每个数据库一个。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
objoid | oid | 任意 oid 属性 | 这条描述所描述的对象的 OID |
classoid | oid | pg_class.oid | 这个对象出现的系统表的 OID |
description | text | 作为对该对象的描述的任意文本 |
pg_statistic
pg_statistic 表存储有关该数据库内容的统计数据。记录是由 ANALYZE 创建的,并且随后被查询规划器使用。请注意所有统计信息天生都是近似的数值,即使假设它是最新的也如此。
pg_statistic 还存储有关索引表达式数值的统计数据。这些是把他们当作实际的数据字段来描述的;特别是,starelid 引用索引。不过,普通的非表达式字段没有记录,因为会和下层的表字段记录冗余。
因为不同类型的统计信息适用于不同类型的数据,pg_statistic 被设计成不太在意自己存储的是什么类型的统计。只有极为常用的统计信息(比如 NULL 的含量)才在 pg_statistic 里给予专用的字段。其它所有东西都存储在"槽位"中,而槽位是一组相关的字段,它们的内容用槽位中的一个字段的代码号码表示。更详细的信息请参阅 src/include/catalog/pg_statistic.h
pg_statistic 不应该是公众可读的,因为即使是表内容的统计信息也应该认为是敏感的。例子:薪水字段的最大最小值肯定是相当让人感兴趣的。pg_stats是一个在 pg_statistic 上的全局可读的视图,它只显示那些表对于当前用户可读的信息。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
starelid | oid | pg_class.oid | 所描述的字段所属的表或者索引 |
staattnum | int2 | pg_attribute.attnum | 所描述的字段的个数 |
stanullfrac | float4 | 该字段中为 NULL 的记录的比率 | |
stawidth | int4 | 非 NULL 记录的平均存储宽度,以字节计 | |
stadistinct | float4 | 字段里唯一的非 NULL 数据值的数目。一个大于零的数值是独立数值的实际数目。一个小于零的数值是表中行数的分数的负数(比如,一个字段的数值平均出现概率为两次,那么可以表示为 stadistinct = -0.5)。零值表示独立数值的数目未知。 | |
stakindN | int2 | 一个编码,表示这种类型的统计存储在 pg_statistic 行的第 N 个"槽位"。 | |
staopN | oid | pg_operator.oid | 一个用于生成这些存储在第 N 个"槽位"的统计信息的操作符。比如,一个柱面图槽位会显示 < 操作符,该操作符定义了该数据的排序顺序。 |
stanumbersN | float4[] | 第 N 个"槽位"的相关类型的数值类型统计,如果该槽位和数值类型没有关系,那么就是 NULL 。 | |
stavaluesN | anyarray | 第 N 个"槽位"相关类型的字段数据值,如果该槽位类型不存储任何数据值那么就是 NULL 。每个数组的元素值实际上都是指定字段的数据类型,因此,除了把这些字段的类型定义成 anyarray 之外,没有更好的办法。 |
pg_tablespace
pg_tablespace 存储有关可用的表空间的信息。表可以放置在特定的表空间里,以帮助管理磁盘布局。
与大多数系统表不同,pg_tablespace 在一个集群中的所有数据库之间共享:每个集群只有一份 pg_tablespace 的拷贝,而不是每个数据库一个。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
spcname | name | 表空间名字 | |
spcowner | oid | pg_authid.oid | 表空间的所有者,通常是创建它的人 |
spclocation | text | 表空间的位置(目录路径) | |
spcacl | aclitem[] | 访问权限 |
pg_trigger
pg_trigger 存储表上面的触发器。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
tgrelid | oid | pg_class.oid | 这个触发器所在的表 |
tgname | name | 触发器名称(在同一表的所有触发器中必须唯一) | |
tgfoid | oid | pg_proc.oid | 要调用的函数 |
tgtype | int2 | 标识触发器条件的位掩码 | |
tgenabled | bool | 如果触发器打开则为真 | |
tgisconstraint | bool | 如果触发器实现一个参照完整性约束则为真 | |
tgconstrname | name | 参照完整性约束的名称 | |
tgconstrrelid | oid | pg_class.oid | 一个参照完整性约束引用的表 |
tgdeferrable | bool | 如果可推迟则为真 | |
tginitdeferred | bool | 如果是初始可推迟则为真 | |
tgnargs | int2 | 传递给触发器函数的参数字符串个数 | |
tgattr | int2vector | 目前未使用 | |
tgargs | bytea | 传递给触发器的参数字符串,每个都是用 NULL 结尾 |
【注意】 pg_class.reltriggers 需要和此表中指定关系上得触发器的个数相等。
pg_type
pg_type 存储有关数据类型的信息。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
typname | name | 数据类型名字 | |
typnamespace | oid | pg_namespace.oid | 包含这个类型的名字空间的 OID |
typowner | oid | pg_authid.oid | 该类型的所有者 |
typlen | int2 | 对于定长类型是该类型内部表现形式的字节数目。对于变长类型是负数。-1 表示一种"变长"类型(有长度字属性的数据),-2 表示这是一个 NULL 结尾的 C 字符串。 | |
typbyval | bool | 判断内部过程传递这个类型的数值时是通过传值还是传引用。如果该类型不是 1, 2, 4, 8 字节长将只能按应用传递,因此 typbyval 最好是假。即使可以传值,typbyval 也可以为假。比如 float4 就是如此。 | |
typtype | char | 对于基础类型是 b ,对于复合类型是 c (比如,一个表的行类型)。对于域类型是 d ,对于伪类型是 p 。又见 typrelid 和 typbasetype | |
typisdefined | bool | 如果定义了类型则为真,如果是一种尚未定义的类型的占位符则为假。如果为假,那么除了该类型名称,名字空间,和 OID 之外没有可靠的信息。 | |
typdelim | char | 当分析数组输入时,分隔两个此类型数值的字符请注意该分隔符是与数组元素数据类型相关联的,而不是和数组数据类型关联。 | |
typrelid | oid | pg_class.oid | 如果是复合类型(见 typtype)那么这个字段指向 pg_class 中定义该表的行。对于自由存在的复合类型,pg_class 记录并不表示一个表,但是总需要它来查找该类型连接的 pg_attribute 记录。对于非复合类型为零。 |
typelem | oid | pg_type.oid | 如果不为 0 ,那么它标识 pg_type 里面的另外一行。当前类型可以当做一个产生类型为 typelem 的数组来描述。一个"真正的"数组类型是变长的(typlen = -1),但是一些定长的(typlen > 0)类型也拥有非零的 typelem(比如 name 和 point)。如果一个定长类型拥有一个 typelem ,那么他的内部形式必须是 typelem 数据类型的某个数目的个数值,不能有其它数据。变长数组类型有一个该数组子过程定义的头(文件)。 |
typinput | regproc | pg_proc.oid | 输入转换函数(文本格式) |
typoutput | regproc | pg_proc.oid | 输出转换函数(文本格式) |
typreceive | regproc | pg_proc.oid | 输入转换函数(二进制格式),如果没有则为 0 |
typsend | regproc | pg_proc.oid | 输出转换函数(二进制格式),如果没有则为 0 |
typanalyze | regproc | pg_proc.oid | 自定义的 ANALYZE 函数,如果使用标准函数,则为 0 |
typalign | char | 当存储此类型的数值时要求的对齐性质。它应用于磁盘存储以及该值在 PostgreSQL 内部的大多数形式。如果数值是连续存放的,比如在磁盘上以完全的裸数据的形式存放时,那么先在此类型的数据前填充空白,这样它就可以按照要求的界限存储。对齐引用是该序列中第一个数据的开头。可能的值有:c = char 对齐,也就是不需要对齐。s = short 对齐(在大多数机器上是 2 字节)i = int 对齐(在大多数机器上是 4 字节)d = double 对齐(在大多数机器上是 8 字节,但不一定是全部)**【注意】**对于在系统表里使用的类型,在 pg_type 里定义的尺寸和对齐必须和编译器在一个表示表的一行的结构里的布局一样。 | |
typstorage | char | 诉一个变长类型(那些有 typlen = -1)的)说该类型是否准备好应付非常规值,以及对这种属性的类型的缺省策略是什么。可能的值有p: 数值总是以简单方式存储e: 数值可以存储在一个"次要"关系中(如果该关系有这么一个,参阅 pg_class.reltoastrelid)m: 数值可以以内联的压缩方式存储x: 数值可以以内联的压缩方式或者在"次要"表里存储。请注意 m 域也可以移到从属表里存储,但只是最后的解决方法(e 和 x 域先移走)。 | |
typnotnull | bool | 代表在某类型上的一个 NOTNULL 约束。目前只用于域。 | |
typbasetype | oid | pg_type.oid | 如果这是一个衍生类型(参阅 typtype),那么该标识作为这个类型的基础的类型。如果不是衍生类型则为零。 |
typtypmod | int4 | 域使用 typtypmod 记录要作用到它们的基础类型上的 typmod (如果基础类型不使用 typmod 则为 -1)。如果这种类型不是域,那么为 -1 。 | |
typndims | int4 | 如果一个域是数组,那么 typndims 是数组维数的数值(也就是说,typbasetype 是一个数组类型;域的 typelem 将匹配基本类型的 typelem)。非域非数组域为零。 | |
typdefaultbin | text | 如果为非 NULL ,那么它是该类型缺省表达式的 nodeToString() 表现形式。目前这个字段只用于域。 | |
typdefault | text | 如果某类型没有相关缺省值,那么 typdefault 是 NULL 。如果 typdefaultbin 不是 NULL ,那么 typdefault 必须包含一个 typdefaultbin 代表的缺省表达式的人类可读的版本。如果 typdefaultbin 为 NULL 但 typdefault 不是,那么 typdefault 是该类型缺省值的外部表现形式,可以把它交给该类型的输入转换器生成一个常量。 |
Postgresql系统视图
概述
除了系统表之外,PostgreSQL 还提供了一系列内置的视图。系统视图提供了查询系统表的一些便利的访问方法。其它一些视图提供了访问内部服务器状态的方法。
信息模式提供了另外一套视图,它的功能覆盖了系统视图的功能。因为信息模式是 SQL 标准,而这里描述的视图是 PostgreSQL 特有的,所以最好用信息模式来获取自己需要的所有信息。
下面是每个视图更详细的信息。有些视图提供了对统计收集器的结果的访问。
除了特别声明的,这里描述的所有视图都是只读的。
视图名 | 用途 |
---|---|
pg_cursors | 打开的游标 |
pg_group | 数据库用户的组 |
pg_indexes | 索引 |
pg_locks | 当前持有的锁 |
pg_prepared_statements | 预备语句 |
pg_prepared_xacts | 预备事务 |
pg_roles | 数据库角色 |
pg_rules | 规则 |
pg_settings | 参数设置 |
pg_shadow | 数据库用户 |
pg_stats | 规划器统计 |
pg_tables | 表 |
pg_timezone_abbrevs | 时区缩写 |
pg_timezone_names | 时区名 |
pg_user | 数据库用户 |
pg_views | 视图 |
pg_cursors
pg_cursors 列出了当前可用的游标。游标可以用几种不同的方法定义:
- 通过 DECLARE语句
- 在前/后端协议中通过 Bind 信息。
- 通过服务器编程接口(SPI)。
pg_cursors 显示上述所有方法创建的游标。除非被声明为 WITH HOLD ,游标仅存在于定义它们的事务的生命期中。因此非持久游标仅能够在视图中存在到创建该游标的事务结束时为止。
pg_cursors 视图是只读的。
**【注意】**因为游标用于在 PostgreSQL 内部实现一些比如过程语言之类的组件。因此 pg_cursors 可能包含并非由用户明确创建的游标。
名字 | 类型 | 描述 |
---|---|---|
name | text | 游标名 |
statement | text | 声明该游标的查询字符串 |
is_holdable | boolean | 如果该游标是持久的(也就是在声明该游标的事务结束后仍然可以访问该游标)则为 true ;否则为 false |
is_binary | boolean | 如果该游标被声明为 BINARY 则为 true ;否则为 false |
is_scrollable | boolean | 如果该游标可以滚动(也就是允许以不连续的方式检索)则为 true ;否则为 false |
creation_time | timestamptz | 声明该游标的时间戳 |
pg_group
pg_group 的存在是为了向下兼容:它模拟一个存在于 PostgreSQL 版本 8.1 之前的系统表。它显示所有标记为不是 rolcanlogin 的角色的名字和成员,这就是近似于用做组的那些角色的集合了。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
groname | name | pg_authid.rolname | 组的名字 |
grosysid | oid | pg_authid.oid | 组的 ID |
grolist | oid[] | pg_authid.oid | 一个数组,包含这个组里面所有角色的 ID |
pg_indexes
pg_indexes 提供对数据库中每个索引的有用信息的访问。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
schemaname | name | pg_namespace.nspname | 包含表和索引的模式的名字 |
tablename | name | pg_class.relname | 此索引所服务的表的名字 |
indexname | name | pg_class.relname | 索引的名字 |
tablespace | name | pg_tablespace.spcname | 包含索引的表空间名字(如果是数据库缺省,则为 NULL) |
indexdef | text | 索引定义(一个重建的 CREATE INDEX 命令) |
pg_locks
pg_locks 提供有关在数据库服务器中由打开的事务持有的锁的信息。
pg_locks 对每个活跃的可锁定对象、请求的锁模式、以及相关的事务保存一行。因此,如果多个事务持有或者等待对同一个对象的锁,那么同一个可锁定的对象可能出现多次。不过,一个目前没有锁在其上的对象将肯定不会出现。
有好几种不同的可锁定对象:一个关系(也就是一个表)、关系中独立页面、关系中独立的行、一个事务 ID 、以及一般的数据库对象(用类别 OID 和对象 OID 标识,表示方法和 pg_description 或 pg_depend一样)还有,扩展一个关系的权限也是用一种独立的可锁定对象表示的。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
locktype | text | 可锁定对象的类型:relation, extend, page, tuple, transactionid, object, userlock, advisory 之一 | |
database | oid | pg_database.oid | 对象所在的数据库的 OID ,如果对象是共享对象,那么就是零,如果对象是一个事务 ID ,就是 NULL 。 |
relation | oid | pg_class.oid | 关系的 OID ,如果对象不是关系,也不是关系的一部分,则为 NULL |
page | integer | 关系内部的页面编号,如果对象不是行页不是关系页,则为 NULL | |
tuple | smallint | 页面里面的行编号,如果对象不是行,则为 NULL | |
transactionid | xid | 事务的 ID ,如果对象不是事务 ID ,就是 NULL | |
classid | oid | pg_class.oid | 包含该对象的系统表的 OID ,如果对象不是普通数据库对象,则为 NULL |
objid | oid | 任意 oid 属性 | 对象在其系统表内的 OID ,如果对象不是普通数据库对象,则为 NULL |
objsubid | smallint | 对于表的一个字段,这是字段编号(classid 和 objid 指向表自身)。对于其它对象类型,这个字段是零。如果这个对象不是普通数据库对象,则为 NULL | |
transaction | xid | 持有此锁或者在等待此锁的事务的 ID | |
pid | integer | 持有或者等待这个锁的服务器进程的进程 ID 。如果锁是被一个预备事务持有的,那么为 NULL | |
mode | text | 这个进程持有的或者是期望的锁模式 | |
granted | boolean | 如果持有锁,为真,如果等待锁,为假 |
granted 为真时表明指定事务持有一个锁。为假则表明该事务当前等待使用这个锁,这就暗示着某个其它的事务正在同样的可锁定对象上持有冲突的锁模式。等待的会话将一直睡眠,直到另外一个锁释放(或者侦测到一个死锁条件)。一个事务一次最多等待一个锁。
每个事务都在它持续的时间里在他自己的事务 ID 上持有一个排他锁。如果一个事务认为它必须等待另外一个事务,它会以企图在另外一个事务 ID 上获取共享锁的方式实现之。这个锁只有在另外一个事务终止并且释放它的锁的前提下才能成功。
尽管行是一种可以锁定的对象,但是有关行级别锁的信息是存储在磁盘上的,而不是在内存里,因此,行级别的锁通常不会出现在这个视图里。如果一个事务在等待一个行级别的锁,那么它通常会在这个视图里以等待当前持有该行锁的事务 ID 的方式出现。
建议锁可以在由单独一个 bigint 值或两个integer值组成的键上获得。一个 bigint 键的高/低位部分分别在 classid 和 objid 字段中显示,并且 objsubid 等于 1 。integer 组成的键前半部分在 classid 字段中显示、后半部分在 objid 字段中显示,并且 objsubid 等于 2 。键的实际含义取决于用户的定义。建议锁是针对单个数据库的,因此 database 字段对于建议锁就显得很有意义了。
在访问 pg_locks 视图的时候,内部的锁管理器数据结构会暂时被锁住,然后制作一份这个视图的拷贝用于显示。这样就保证了视图生成一套连贯的结果,它不会不必要地过分阻塞普通的锁管理器。但是如果这个视图访问得太频繁,肯定是会对数据库性能有些影响的。
pg_locks 提供了一个数据库集群里的所有的锁的全局视图,而不仅仅那些和当前数据库相关的。尽管它的 relation 字段可以和 pg_class.oid 连接起来以标识被锁住的关系,但是这个方法目前只能对在当前数据库里的关系有用(那些 database 字段是当前数据库的 OID 或者零的数据库)。
如果你打开了统计收集器,pid 字段可以可以和 pg_stat_activity 视图的 procpid 字段连接起来获取持有或者等待持有这个锁的会话的更多信息。同样,如果你使用预备事务,可以把 transaction 字段和 pg_prepared_xacts 视图的 transaction 字段连接起来获取持有锁的那个预备事务的更多信息。一个预备事务不能等待任何锁,但是在运行的时候,它继续持有它已经请求到的锁。
pg_prepared_statements
pg_prepared_statements 显示所有当前会话中可用的预备语句。
pg_prepared_statements 视图是只读的。
每个预备语句在 pg_prepared_statements 中都有对应的一条记录。当一条新的预备语句创建后该视图中就会新增一条记录,同样,当一条预备语句被释放后(比如通过 DEALLOCATE命令),相应的记录也会被删除。
名字 | 类型 | 描述 |
---|---|---|
name | text | 预备语句的标识符 |
statement | text | 创建该预备语句的查询字符串。对于从 SQL 创建的预备语句而言是客户端提交的 PREPARE 语句。对于通过前/后端协议创建的预备语句而言是预备语句自身的文本。 |
prepare_time | timestamptz | 创建该预备语句的时间戳 |
parameter_types | regtype[] | 该预备语句期望的参数类型,以 regtype 类型的数组格式出现。与该数组元素相对应的 OID 可以通过把 regtype 值转换为 oid 值得到。 |
from_sql | boolean | 如果该预备语句是通过 PREPARE 语句创建的则为 true ;如果是通过前/后端协议创建的则为 false |
pg_prepared_xacts
pg_prepared_xacts 显示那些当前准备好进行两阶段提交的事务的信息。
pg_prepared_xacts 为每个预备事务包含一行。如果事务提交或者回滚,则删除该条记录。
在访问 pg_prepared_xacts 视图的时候,内部事务管理器数据结构被暂时锁住,并且为显示视图制作了一份拷贝。这样就保证了视图生成一个一致的结果集,而不会阻塞正常的操作太长时间。当然,即便这么做,如果过于频繁地访问这个视图,肯定也会对数据库性能造成一定的影响。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
transaction | xid | 预备事务的数字事务标识 | |
gid | text | 赋予该事务的全局事务标识 | |
prepared | timestamp with time zone | 事务准备好提交的时间 | |
owner | name | pg_authid.rolname | 执行该事务的用户的名字 |
database | name | pg_database.datname | 执行该事务所在的数据库名 |
pg_roles
pg_roles 提供访问数据库角色有关信息的接口。它只是一个 pg_authid表的公开可读部分的视图,把口令字段用空白填充了。
该视图明确的显示了底层表的 OID 字段,可以用于与其它表连接。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
rolname | name | 角色名 | |
rolsuper | bool | 有超级用户权限的角色 | |
rolinherit | bool | 自动继承属主角色权限的角色 | |
rolcreaterole | bool | 可以创建更多角色的角色 | |
rolcreatedb | bool | 可以创建数据库的角色 | |
rolcatupdate | bool | 可以直接更新系统表的角色。除非这个字段为真,否则超级用户也不能干这个事情。 | |
rolcanlogin | bool | 可以登录的角色,也就是说,这个角色可以给予初始化会话认证的标识符。 | |
rolconnlimit | int4 | 对于可以登录的角色,这儿限制了该角色允许发起的最大并发连接数。 -1 表示无限制。 | |
rolpassword | text | 不是口令(总是 ********) | |
rolvaliduntil | timestamptz | 口令失效日期(只用于口令认证);如果没有失效期,为 NULL | |
rolconfig | text[] | 运行时配置变量的会话缺省 | |
oid | oid | pg_authid.oid | 角色的 ID |
pg_rules
pg_rules 提供对查询重写规则的有用信息访问的接口。
pg_rules 视图排除了视图的 ON SELECT 规则;就是那些可以在 pg_views 里看到的。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
schemaname | name | pg_namespace.nspname | 包含表的模式的名字 |
tablename | name | pg_class.relname | 规则作用的表的名字 |
rulename | name | pg_rewrite.rulename | 规则的名字 |
definition | text | 规则定义(一个重新构造的创建命令) |
pg_settings
pg_settings 提供了对服务器运行时参数的访问。它实际上是 SHOW 和 SET 命令的另外一个接口。它还提供一些用 SHOW 不能直接获取的参数的访问,比如最大和最小值。
名字 | 类型 | 描述 | |
---|---|---|---|
name | text | 运行时配置参数名 | |
setting | text | 参数的当前值 | |
unit | text | 参数的隐含单元 | |
category | text | 参数的逻辑组 | |
short_desc | text | 参数的一个简短的描述 | |
extra_desc | text | 有关参数的额外的,更详细的信息 | |
context | text | 设置这个参数的值要求的环境 | |
vartype | text | 参数类型(bool, integer, real, string) | |
source | text | 当前参数值的来源 | |
min_val | text | 该参数允许的最小值(非数字值为 NULL) | |
max_val | text | 这个参数允许的最大的数值(非数字值为 NULL) |
不能对 pg_settings 视图进行插入或者删除,但是可以更新。对 pg_settings 中的一行进行 UPDATE 等效于在该命名参数上执行 SET命令。这个修改值影响当前会话使用的数值。如果在一个最后退出的事务中发出了 UPDATE 命令,那么 UPDATE 命令的效果将在事务回滚之后消失。一旦包围它的事务提交,这个效果将固化,直到会话结束,除非由其它的 UPDATE 或 SET 命令覆盖。
pg_shadow
pg_shadow 存在是为了向下兼容:它模拟了一个 PostgreSQL 版本 8.1 之前的系统表。它显示了所有标记了 rolcanlogin 的角色的属性。
这个系统表的名字来自于该表不能被公众可读,因为它包含口令。pg_user是一个在 pg_shadow 上公开可读的视图,只是把口令域填成了空白。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
usename | name | pg_authid.rolname | 用户名 |
usesysid | oid | pg_authid.oid | 用户的 ID |
usecreatedb | bool | 用户可以创建数据库 | |
usesuper | bool | 用户是超级用户 | |
usecatupd | bool | 用户可以更新系统表。即使超级用户,如果这个字段不是真,也不能更新系统表。 | |
passwd | text | 口令(可能是加密的) | |
valuntil | abstime | 口令失效的时间(只用于口令认证) | |
useconfig | text[] | 运行时配置变量的会话缺省 |
pg_stats
pg_stats 提供对存储在 pg_statistic表里面的信息的访问。这个视图允许只访问那些在 pg_statistic 里面对应用户有权限读取的表的数据行,因此可以安全地允许公众访问这个视图。
pg_stats 也设计成把信息以一种更易读的方式出现的形式,它比下层的系统表更容易阅读,代价就是如果在 pg_statistic 里定义了新的数据槽位,那么必须扩展它的视图定义。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
schemaname | name | pg_namespace.nspname | 包含此表的模式名字 |
tablename | name | pg_class.relname | 表的名字 |
attname | name | pg_attribute.attname | 这一行描述的字段的名字 |
null_frac | real | 记录中字段为空的百分比 | |
avg_width | integer | 字段记录以字节记的平均宽度 | |
n_distinct | real | 如果大于零,就是在字段中独立数值的估计数目。如果小于零,就是独立数值的数目被行数除的负数。用负数形式是因为 ANALYZE 认为独立数值的数目是随着表增长而增长;正数的形式用于在字段看上去好像有固定的可能值数目的情况下。比如,-1 表示一个唯一字段,独立数值的个数和行数相同。 | |
most_common_vals | anyarray | 一个字段里最常用数值的列表。如果看上去没有啥数值比其它更常见,则为 NULL | |
most_common_freqs | real[] | 一个最常用数值的频率的列表,也就是说,每个出现的次数除以行数。如果 most_common_vals 是 NULL ,则为 NULL | |
histogram_bounds | anyarray | 一个数值的列表,它把字段的数值分成几组大致相同热门的组。如果在 most_common_vals 里有数值,则在这个饼图的计算中省略。如果字段数据类型没有 < 操作符或者 most_common_vals 列表代表了整个分布性,则这个字段为 NULL 。 | |
correlation | real | 统计与字段值的物理行序和逻辑行序有关。它的范围从 -1 到 +1 。在数值接近 -1 或者 +1 的时候,在字段上的索引扫描将被认为比它接近零的时候开销更少,因为减少了对磁盘的随机访问。如果字段数据类型没有 < 操作符,那么这个字段为 NULL 。 |
在 most_common_vals 和 histogram_bounds 数组里的元素的最大数目可以用 ALTER TABLE SET STATISTICS 命令一个一个字段地设置,或者通过设置运行时参数 default_statistics_target全局地设置。
pg_tables
pg_tables 提供了对有关数据库中每个表的有用信息地访问。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
schemaname | name | pg_namespace.nspname | 包含表的模式名字 |
tablename | name | pg_class.relname | 表的名字 |
tableowner | name | pg_authid.rolname | 表的所有者的名字 |
tablespace | name | pg_tablespace.spcname | 包含表的表空间名字(如果是数据库缺省,则为 NULL) |
hasindexes | boolean | pg_class.relhasindex | 如果表拥有(或者最近拥有)任何索引,则为真 |
hasrules | boolean | pg_class.relhasrules | 如果表有规则,则为真 |
hastriggers | boolean | pg_class.reltriggers | 如果表有触发器,则为真 |
pg_timezone_abbrevs
pg_timezone_abbrevs 提供了输入例程能够识别的所有时区缩写。当运行时参数 timezone_abbreviations发生改变的时候,该视图的内容也会发生改变。
名字 | 类型 | 描述 |
---|---|---|
abbrev | text | 时区缩写 |
utc_offset | interval | 相对于 UTC 的偏移量 |
is_dst | boolean | 如果这是一个夏时制时区缩写则为真 |
pg_timezone_names
pg_timezone_names 显示了所有能够被 SET TIMEZONE 识别的时区名及其缩写、UTC 偏移量、是否夏时制。不同于在 pg_timezone_abbrevs中显示的缩写,许多这些名字都隐含着夏令时转换规则。因此,在跨越夏令时边界时香瓜信息会发生变化。显示的信息给予当前的 CURRENT_TIMESTAMP 值进行计算。
名字 | 类型 | 描述 |
---|---|---|
name | text | 时区名 |
abbrev | text | 时区缩写 |
utc_offset | interval | 相对于 UTC 的偏移量 |
is_dst | boolean | 如果当前正处于夏令时范围则为真 |
pg_user
pg_user 提供了对数据库用户的相关信息的访问。这个视图只是一个 pg_shadow的公众可读的部分的视图化,它把口令域给刷掉了。
名字 | 类型 | 描述 |
---|---|---|
usename | name | 用户名 |
usesysid | int4 | 用户 ID(用于引用这个用户的任意数字) |
usecreatedb | bool | 用户可以创建数据库 |
usesuper | bool | 用户是一个超级用户 |
usecatupd | bool | 用户可以更新系统表。即使超级用户也不能这么干,除非这个字段为真。 |
passwd | text | 不是口令(总是为 ********) |
valuntil | abstime | 口令失效的时间(只用于口令认证) |
useconfig | text[] | 运行时配置参数的会话缺省 |
pg_views
pg_views 提供了对数据库里每个视图的有用信息的访问途径。
名字 | 类型 | 引用 | 描述 |
---|---|---|---|
schemaname | name | pg_namespace.nspname | 包含此视图的模式名字 |
viewname | name | pg_class.relname | 视图的名字 |
viewowner | name | pg_authid.rolname | 视图的所有者的名字 |
definition | text | 视图定义(一个重建的 SELECT 查询) |