51.7. pg_attribute
目录pg_attribute
存储有关表列的信息。数据库中每个表中的每一列都会有一个pg_attribute
行。 (还将有索引的属性条目,以及实际上所有具有pg_class
条目的对象.)
术语属性等效于列,出于历史原因使用。
表 51.7. pg_attribute
列
Name | Type | References | Description |
---|---|---|---|
attrelid | oid | pg_class.oid | 该列所属的表 |
attname | name | 列名 | |
atttypid | oid | pg_type.oid | 该列的数据类型 |
attstattarget | int4 | attstattarget 控制ANALYZE为该列累积的统计信息的详细程度。零值表示不应收集统计信息。负值表示使用系统默认统计信息目标。正值的确切含义取决于数据类型。对于标量数据类型,attstattarget 既是要收集的“最常见值”的目标数,也是要创建的直方图 bin 的目标数。 | |
attlen | int2 | 此列类型的pg_type.typlen 的副本 | |
attnum | int2 | 列号。普通列从 1 开始编号。系统列(例如oid )具有(任意)负数。 | |
attndims | int4 | 维数(如果列为数组类型);否则为 0.(当前,不强制执行数组的维数,因此任何非零值实际上表示“它是数组”.) | |
attcacheoff | int4 | 在存储中始终为-1,但是当加载到内存中的行 Descriptors 时,可能会对其进行更新以缓存该行中属性的偏移量 | |
atttypmod | int4 | atttypmod 记录在表创建时提供的特定于类型的数据(例如varchar 列的最大长度)。它传递给特定于类型的 Importing 函数和长度强制函数。对于不需要atttypmod 的类型,该值通常为-1. | |
attbyval | bool | 此列类型的pg_type.typbyval 的副本 | |
attstorage | char | 通常,此列类型的pg_type.typstorage 的副本。对于可 TOAST 的数据类型,可以在创建列之后更改此设置以控制存储策略。 | |
attalign | char | 此列类型的pg_type.typalign 的副本 | |
attnotnull | bool | 这表示非空约束。 | |
atthasdef | bool | 此列具有默认值,在这种情况下,pg_attrdef 目录中将存在一个实际定义该值的对应条目。 | |
attidentity | char | 如果为零字节('' ),则不是标识列。否则,a =始终生成,d =默认生成。 | |
attisdropped | bool | 该列已被删除,不再有效。删除的列实际上仍然存在于表中,但是解析器将忽略它,因此无法通过 SQL 对其进行访问。 | |
attislocal | bool | 此列在关系中本地定义。请注意,可以在本地定义列并同时继承列。 | |
attinhcount | int4 | 此列具有的直接祖先数。祖先数不为零的列不能删除或重命名。 | |
attcollation | oid | pg_collation.oid | 列的已定义排序规则;如果列不是可排序数据类型,则为零。 |
attacl | aclitem[] | 列级访问特权(如果已在此列上专门授予了任何特权) | |
attoptions | text[] | 属性级别选项,作为“关键字=值”字符串 | |
attfdwoptions | text[] | 属性级别的外部数据包装器选项,如“ keyword = value”字符串 |
在已删除列的pg_attribute
条目中,atttypid
重置为零,但是attlen
和从pg_type
复制的其他字段仍然有效。需要这种安排来应对后来删除的列的数据类型被删除的情况,因此不再有pg_type
行。 attlen
和其他字段可用于解释表中一行的内容。