受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

52.20. pg_enum #

pg_enum目录包含每一个枚举类型的项,其中包括了值和标签。一个给定枚举值的内部表示实际上是它在pg_enum中的相关行的OID。

Table 52.20. pg_enum

列类型

描述

oid oid

行标识符

enumtypid oid (引用 pg_type.oid

包含此枚举值的pg_type项的OID

enumsortorder float4

此枚举值在其枚举类型中的排序位置

enumlabel name

此枚举值的文本标签


pg_enum行的OID值遵循一种特殊的规则:即OID的数值被保证按照其枚举类型的排序顺序进行排序。即如果两个偶数OID属于同一枚举类型,较小的OID必然具有较小的enumsortorder值。奇数OID值不需要遵循排序顺序。这种规则使得枚举比较例程在很多常见情况下可以避免系统目录查找。创建和修改枚举类型的例程将尝试尽可能地为枚举值分配偶数OID。

当一个枚举类型被创建后,其成员会被分配排序位置 1..n。但后来增加的成员可能会被赋予负值或分数值的enumsortorder。对这些值的唯一要求是它们必须排序正确并且保持唯一。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。