PostgreSQL学习手册(系统表)
PostgreSQL学习手册(系统表)一、pg_class:该系统表记录了数据表、索引(仍然需要参阅pg_index)、序列、视图、复合类型和一些特殊关系类型的元数据。注意:不是所有字段对所有对象类型都有意义。名字 类型 引用 描述relname name 数据类型名字。relnamespace oid pg_namespace.oid 包含这个对象的名字空间(模式)的OI。reltype oid pg_type.oid 对应这个表的行类型的数据类型。relowner oid pg_authid.oid 对象的所有者。 www.zzzyk.comrelam 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 www.zzzyk.com-------------+----------testtable | postgres(1 row)二、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表里实际定义此值的记录。attisdropped bool 该字段是否已经被删除。如果被删除,该字段在物理上仍然存在表中,但会被分析器忽略,因此不能再通过SQL访问。attislocal bool 该字段是否局部定义在对象中的。attinhcount int4 该字段所拥有的直接祖先的个数。如果一个字段的祖先个数非零,那么它就不能被删除或重命名。见如下应用示例:#查看指定表中包含的字段名和字段编号。postgres=# SELECT relname, attname,attnum FROM pg_class c,pg_attribute attr WHERE relname = 'testtable' AND c.oid = attr.attrelid;relname | attname | attnum-------------+----------+--------testtable | tableoid | -7testtable | cmax | -6testtable | xmax | -5testtable | cmin | -4testtable | xmin | -3testtable | ctid | -1testtable | i | 1(7 rows)#只查看用户自定义字段的类型postgres=# SELECT relname,attname,typname FROM pg_class c,pg_attribute a,pg_type t WHERE c.relname = 'testtable' AND c.oid = attrelid AND atttypid = t.oid AND attnum > 0;relname | attname | typname www.zzzyk.com-------------+----------+---------testtable | i | int4(7 rows)三、pg_attrdef:该系统表主要存储字段缺省值,字段中的主要信息存放在pg_attribute系统表中。注意:只有明确声明了缺省值的字段在该表中才会有记录。名字 类型 引用 描述adrelid oid pg_class.oid 这个字段所属的表adnum int2 pg_attribute.attnum 字段编号,其规则等同于pg_attribute.attnumadbin text 字段缺省值的内部表现形式。adsrc text 缺省值的人可读的表现形式。见如下应用示例:#查看指定表有哪些字段存在缺省值,同时显示出字段名和缺省值的定义方式postgres=# CREATE TABLE testtable2 (i integer DEFAULT 100);CREATE TABLEpostgres=# SELECT c.relname, a.attname, ad.adnum, ad.adsrc FROM pg_class c, pg_attribute a, pg_attrdef ad WHERE relname = 'testtable2' AND ad.adrelid = c.oid AND adnum = a.attnum AND attrelid = c.oid;relname | attname | adnum | adsrc-------------+----------+---------+-------testtable2 | i | 1 | 100(1 row)四、pg_authid:该系统表存储有关数据库认证的角色信息上一个:mongodb常用管理命令
下一个:各种数据库临时表的使用区别总结
- 更多SQLServer疑问解答:
- 配置MSSQL复制指定快照文件夹提示:不是有效的路径或文件名
- 详细解读varchar和Nvarchar区别
- SQL SERVER 2005 同步复制技术
- 进程未能大容量复制到表 解决方法
- MSSql实例教程:MSSql数据库同步
- SQLServer2000同步复制技术实现(分发和订阅)
- sqlserver
- SQLSERVER
- 测试 sqlserver 最大用户数连接
- 写出一条Sql语句:取出表A中第31到第40记录(SQLServer,以自动增长的ID作为主键,注意:ID可能不是连续的
- sqlserver2008的安装问题。
- 为什么安装的SQL server 2008我的没有MSSQLSERVER协议啊?
- 怎样把exel表里的数据复制到sqlserver表里
- sqlserver数据库主键和外键问题
- sqlserver 中的左表连接查询和右表连接查询有啥不同?有什么用?