oid oid
行标识符
|
typname name
数据类型的名字
|
typnamespace oid
(references pg_namespace .oid )
包含此类型的名字空间的OID
|
typowner oid
(references pg_authid .oid )
类型的拥有者
|
typlen int2
对于一个固定尺寸的类型,typlen 是该类型内部表示的字节数。
对于一个变长类型,typlen 为负值。
-1表示一个“varlena”类型(具有长度字),-2表示一个以空值结尾的C字符串。
|
typbyval bool
typbyval 判断内部例程传递这个类型的数值时是通过传值还是传引用。
如果typlen 不是1、2或4(或者在Datum为8字节的机器上为8),因此typbyval 最好是假。
变长类型总是传引用。注意即使长度允许传值, typbyval 也可以为假。
|
typtype char
typtype 可以是:
b 表示一个基类,
c 表示一个组合类型(例如一个表的行类型),
d 表示一个域,
e 表示一个枚举类型,
p 表示一个伪类型,
r 表示一个范围类型,或
m 表示一个多范围类型。
另请参阅typrelid 和typbasetype .
|
typcategory char
typcategory 是一种任意的数据类型分类,它被分析器用来决定哪种隐式转换“更好”。参见表 53.65。
|
typispreferred bool
如果此类型在它的typcategory 中是一个更好的转换目标,此列为真
|
typisdefined bool
如果此类型已被定义则为真,如果此类型只是一个表示还未定义类型的占位符则为假。
当typisdefined 为假,除了类型名字、名字空间和OID之外什么都不能被依赖。
|
typdelim char
在分析数组输入时,分隔两个此类型值的字符。注意该分隔符是与数组元素数据类型相关联的, 而不是和数组的数据类型关联。
|
typrelid oid
(references pg_class .oid )
如果这是一个复合类型(见typtype ), 那么这个列指向pg_class 中定义对应表的项
(对于自由存在的复合类型,pg_class 项并不表示一个表,但不管怎样该类型的pg_attribute 项需要链接到它)。
对非复合类型此列为零。
|
typsubscript regproc
(references pg_proc .oid )
下标处理函数的OID,如果该类型不支持下标则为零。
“true”数组类型的类型有typsubscript = array_subscript_handler ,但是其他类型有其他的处理函数以实现特定的下标行为。
|
typelem oid
(参考 pg_type .oid )
如果typelem 不为零,则它标识pg_type 里面的另外一行。
如果typsubscript 为零则该项为零。
但是,当typsubscript 不为零时它也可以为零,如果处理机不需要typelem 来决定下标结果类型。
注意typelem 依赖被认为是表示该类型中的元素类型的物理包含;所以这个元素类型上的DDL变更可能会受到该类型存在的限制。
|
typarray oid
(参考 pg_type .oid )
如果typarray 不是零,则它标识pg_type 中的另一行,这一行是一个将此类型作为元素的“真的”数组类型
|
typinput regproc
(references pg_proc .oid )
输入转换函数(文本格式)
|
typoutput regproc
(references pg_proc .oid )
输出转换函数(文本格式)
|
typreceive regproc
(references pg_proc .oid )
输入转换函数(二进制格式),如果没有则为零
|
typsend regproc
(参考 pg_proc .oid )
输出转换函数(二进制格式),如果没有则为零
|
typmodin regproc
(参考 pg_proc .oid )
类型修改器输入函数,如果类型没有提供修改器则为零
|
typmodout regproc
(参考 pg_proc .oid )
类型修改器输出函数,或为零以使用标准格式
|
typanalyze regproc
(参考 pg_proc .oid )
自定义ANALYZE函数,零表示使用标准函数
|
typalign char
typalign 是当存储此类型值时要求的对齐性质。
它应用于磁盘存储以及该值在 PostgreSQL内部的大多数表现形式。
如果数值是连续存放的,比如在磁盘上的一个完整行,在这种类型的数据前会插入填充,这样它就可以按照指定边界存储。
对齐引用是该序列中第一个数据的开头。对齐引用是序列中第一个数据的开始。
可能的值为:
|
typstorage char
如果一个变长类型(typlen = -1)可被TOAST,typstorage 说明这种类型的列应采取的默认策略。
可能的值是:
p (普通的): 值必须始终以普通方式存储(非varlena类型总是使用这个值)。
e (外部的): 值可以存储在一个次要 “TOAST” 关系中 (如果有一个关系, 参见pg_class.reltoastrelid ).
m (主要的): 值可以被压缩并内联存储。
x (扩展的): 值可以被压缩和/或移动到次要关系。
x toast-able 类型的常用选项。
注意m 值也可以被移动到二级存储,但只能是作为最后一种方案(e 和x 值会先被移动)。
|
typnotnull bool
typnotnull 表示类型上的一个非空约束。只用于域。
|
typbasetype oid
(references pg_type .oid )
如果这是一个域(见typtype ),则typbasetype 标识这个域基于的类。如果此类不是一个域则为0。
|
typtypmod int4
域使用typtypmod 来记录被应用于它们基类型的typmod (如果基类型不使用typmod ,则为-1)。如果此类型不是一个域则为-1。
|
typndims int4
对于一个数组上的域,typndims 是数组维度数(即,typbasetype 是一个数组类型)。除数组类型上的域之外的类型的此列为0。
|
typcollation oid
(references pg_collation .oid )
typcollation 指定此类型的排序规则。如果类型不支持排序规则,此列为0。
一个支持排序规则的基类型此处会有一个非零值,典型值为DEFAULT_COLLATION_OID 。
可排序类型上的域可以有一个不同于其基类型的排序规则OID,如果为该域指定了一个排序规则OID的话。
|
typdefaultbin pg_node_tree
如果typdefaultbin 为非空,那么它是 该类型默认表达式的nodeToString() 表现形式。这个列只用于域。
|
typdefault text
如果某类型没有相关默认值,那么typdefault 为空。如果typdefaultbin 不为空, 那么typdefault 必须包含一个typdefaultbin 所指的默认表达式的人类可读的版本。
如果typdefaultbin 为空但typdefault 不为空,则typdefault 是该类型默认值的外部表现形式, 它可以被交给该类型的输入转换器来产生一个常量。
|
typacl aclitem[]
访问权限,另请参阅第 5.7 节
|