• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >PostgreSQL > PostgreSQL教程(十五):系统表详解

PostgreSQL教程(十五):系统表详解

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了postgresql教程,postgresql安装教程,postgresql使用教程,postgresql视频教程,postgresql数据库教程等相关知识,希望本文的分享对您有所帮助

一、pg_class:

    该系统表记录了数据表、索引(仍然需要参阅pg_index)、序列、视图、复合类型和一些特殊关系类型的元数据。注意:不是所有字段对所有对象类型都有意义。

 

名字 类型 引用 描述
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[]   访问权限。

 见如下应用示例:
      #查看指定表对象testtable的模式
    postgres=# SELECT relname,relnamespace,nspname FROM pg_class c,pg_namespace n WHERE relname = 'testtable' AND relnamespace = n.oid;
      relname   | relnamespace | nspname
    -------------+--------------+---------
     testtable   |         2200    | public
    (1 row)
    #查看指定表对象testtable的owner(即role)。
    postgres=# select relname,rolname from pg_class c,pg_authid au where relname = 'testtable' and relowner = au.oid;
      relname   | rolname
    -------------+----------
     testtable   | postgres
    (1 row)
</div>

二、pg_attribute:

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

 

名字 类型 引用 描述
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表里
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • CentOS 7下安装PostgreSQL 9.6的教程分享
  • windows PostgreSQL 9.1 安装详细步骤
  • 深入解读PostgreSQL中的序列及其相关函数的用法
  • PostgreSQL教程(二十):PL/pgSQL过程语言
  • PostgreSQL教程(十九):SQL语言函数
  • PostgreSQL教程(十六):系统视图详解
  • PostgreSQL教程(十五):系统表详解
  • PostgreSQL教程(十四):数据库维护
  • PostgreSQL教程(十二):角色和权限管理介绍
  • PostgreSQL教程(十一):服务器配置

相关文章

  • 2017-05-11PostgreSQL教程(十三):数据库管理详解
  • 2017-05-11PostgreSQL安装、配置及简单使用方法
  • 2017-05-11phpPgAdmin 配置文件参数说明中文版
  • 2017-05-11Mac OS上安装PostgreSQL的教程
  • 2017-05-11CentOS中运行PostgreSQL需要修改的内核参数及配置脚本分享
  • 2017-05-1115个postgresql数据库实用命令分享
  • 2017-05-11PostgreSQL新手入门教程
  • 2017-09-08postgresql 数据库时间间隔数据查询
  • 2017-05-11PostgreSQL教程(十九):SQL语言函数
  • 2017-05-11Linux CentOS 7源码编译安装PostgreSQL9.5

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • Windows PostgreSQL 安装图文教程
    • 用一整天的时间安装postgreSQL NTFS权限
    • Debian中PostgreSQL数据库安装配置实例
    • PostgreSQL教程(十七):客户端命令(1)
    • PostgreSQL教程(十九):SQL语言函数
    • Linux CentOS 7安装PostgreSQL9.3图文教程
    • PostgreSQL新手入门教程
    • PostgreSQL 角色与用户管理介绍
    • phpPgAdmin 配置文件参数说明中文版
    • 解决PostgreSQL服务启动后占用100% CPU卡死的问题

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有