• PostgreSQL之系统表


    定义

    系统表的定义:

    系统表是存放系统信息的普通表或者视图

    pg中总共包括56张系统表和23个系统视图,系统视图建立在系统表之上

    系统表的创建

    pg的每一个数据库中都有一套自己的系统表,其中大多数系统表都是在数据库创建时从模板数据库中拷贝过来的

    系统表的维护

    系统表中的信息由sql命令关联的系统表操作来自动维护

    系统表的存储方式

    和数据库相关的系统表保存在/data/base目录下相应数据库的文件夹下,文件夹命名为pg_database里记录的数据库oid

    数据库集群共享的系统表,如pg_database,保存在/data/global下

    举例:

     系统在运行时对系统表的访问会非常频繁,为了提高性能,pg会在内存中建立共享系统表cache,使用hash函数和hash表去提高查询效率

    查看系统表

    列出所有pg开头的系统表

    dt pg_*

     列出所有pg开头的系统视图

    dv pg_*

    常用系统表

    pg_database

    系统中每创建一个database都会在pg_database中插入一行,这一行对应的oid就是数据库的oid,删除数据库也会删除对应的行

    和大多数系统表不同的是,在一个集群里该表是所有数据库共享的,即每个集群只有一份pg_database拷贝,而不是每个数据库一份。

     关键字段含义

    名字 类型 引用 描述
    datname name   数据库名称。
    datdba oid pg_authid.oid 数据库所有者,通常为创建该数据库的角色。
    encoding int4   数据库的字符编码方式。
    datistemplate bool   如果为真,此数据库可以用于CREATE DATABASE TEMPLATE子句,把新数据库创建为此数据库的克隆。
    datallowconn bool   如果为假,则没有人可以联接到这个数据库。
    datlastsysoid oid   数据库里最后一个系统OID,此值对pg_dump特别有用。
    datvacuumxid xid    
    datfrozenxid xid    
    dattablespace text pg_tablespace.oid 该数据库的缺省表空间。在这个数据库里,所有pg_class.reltablespace为零的表都将保存在这个表空间里,特别要指出的是,所有非共享的系统表也都存放在这里。
    datconfig text[]   运行时配置变量的会话缺省值。
    datacl aclitem[]   访问权限。

     pg_class

     pg_class存储表以及类似表的数据库对象信息,包括索引,序列、视图和复合数据类型等(也可以称做--关系表)

    系统中每创建一个表(视图,索引,序列),都会在pg_class中自动插入一行,这一行的oid属性就是该关系的oid

    所有的系统表系统索引TOAST表,视图,包括pg_class本身,都在pg_class中有对应的行

    名字 类型 引用 描述
    relname name   数据类型名字。
    relnamespace oid pg_namespace.oid 包含这个对象的名字空间(模式)的OI。
    reltype oid pg_type.oid 对应这个表的行类型的数据类型。
    relowner oid pg_authid.oid 对象的所有者。
    relam oid pg_am.oid 对于索引对象,表示该索引的类型(B-tree,hash)。
    relfilenode oid   对象存储在磁盘上的文件名,如果没有则为0。
    reltablespace oid pg_tablespace.oid 对象所在的表空间。如果为零,则表示使用该数据库的缺省表空间。(如果对象在磁盘上没有文件,这个字段就没有什么意义)
    relpages int4   该数据表或索引所占用的磁盘页面数量,查询规划器会借助该值选择最优路径。
    reltuples float4   表中行的数量,该值只是被规划器使用的一个估计值。
    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    如果该表在整个集群中由所有数据库共享,则为真。 
    relkind char   r = 普通表,i = 索引,S = 序列,v = 视图, c = 复合类型,s = 特殊,t = TOAST表
    relnatts int2   数据表中用户字段的数量(除了系统字段以外,如oid)。在pg_attribute里肯定有相同数目的数据行。见pg_attribute.attnum.
    relchecks int2   表中检查约束的数量,参阅pg_constraint表。
    reltriggers int2   表中触发器的数量;参阅pg_trigger表。
    relhasoids bool   如果我们为对象中的每行都生成一个OID,则为真。
    relhaspkey bool   如果该表存在主键,则为真。
    relhasrules  bool   如表有规则就为真;参阅pg_rewrite表。
    relhassubclass bool    如果该表有子表,则为真。
    relacl aclitem[]   访问权限。

     pg_attribute

      该系统表存储所有表(包括系统表,如pg_class)的字段信息。数据库中的每个表的每个字段在pg_attribute表中都有一行记录。

      系统中每个表都有唯一的oid。在每个表中,属性都有唯一的编号,负数编号是系统属性,正数编号是用户定义的属性。

    名字 类型 引用 描述
    attrelid oid pg_class.oid 此字段所属的表。
    attname name   字段名。
    atttypid oid pg_type.oid 字段的数据类型。
    attstattarget int4   attstattarget控制ANALYZE为这个字段设置的统计细节的级别。零值表示不收集统计信息,负数表示使用系统缺省的统计对象。正数值的确切信息是和数据类型相关的。
    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字段值的拷贝。
    attalign char   pg_type.typalign字段值的拷贝。
    attnotnull bool   如果该字段带有非空约束,则为真,否则为假。
    atthasdef bool   该字段是否存在缺省值,此时它对应pg_attrdef表里实际定义此值的记录。
    attisdropped bool   该字段是否已经被删除。如果被删除,该字段在物理上仍然存在表中,但会被分析器忽略,因此不能再通过SQL访问。
    attislocal bool   该字段是否局部定义在对象中的。
    attinhcount int4   该字段所拥有的直接祖先的个数。如果一个字段的祖先个数非零,那么它就不能被删除或重命名。

     

    但行好事,莫问前程
  • 相关阅读:
    静态函数的访问修饰符的问题
    DropDownList 控件控制Image控件动态显示图像
    使用网页对话框来显示图片 window.open()
    用Response.Redirect()方法进行页面的传值
    XML DTD文档定义语法汇总
    json字符串片段转换成HTML片段字符串的问题
    细数改善WPF应用程序性能的10大方法(转)
    C#递归算法-遍历XML文件,以UL列表显示树形结构目录
    我的博客园
    CSDN,让我暴得好彻底......
  • 原文地址:https://www.cnblogs.com/mingfan/p/14379690.html
Copyright © 2020-2023  润新知