9.10. 枚举支持功能

对于枚举类型(在Section 8.7中进行了描述),有几个函数可用于更简洁的编程,而无需硬编码枚举类型的特定值。这些列在Table 9.32中。这些示例假定创建的枚举类型为:

CREATE TYPE rainbow AS ENUM ('red', 'orange', 'yellow', 'green', 'blue', 'purple');

表 9.32. 枚举支持功能

FunctionDescriptionExampleExample Result
enum_first(anyenum)返回 Importing 枚举类型的第一个值enum_first(null::rainbow)red
enum_last(anyenum)返回 Importing 枚举类型的最后一个值enum_last(null::rainbow)purple
enum_range(anyenum)返回有序数组中 Importing 枚举类型的所有值enum_range(null::rainbow){red,orange,yellow,green,blue,purple}
enum_range(anyenum, anyenum)以有序数组的形式返回两个给定枚举值之间的范围。这些值必须来自相同的枚举类型。如果第一个参数为 null,则结果将从枚举类型的第一个值开始。如果第二个参数为 null,则结果将以枚举类型的最后一个值结尾。enum_range('orange'::rainbow, 'green'::rainbow){orange,yellow,green}
enum_range(NULL, 'green'::rainbow){red,orange,yellow,green}
enum_range('orange'::rainbow, NULL){orange,yellow,green,blue,purple}

注意,除了enum_range的两个参数形式外,这些函数无视传递给它们的特定值。他们只关心其声明的数据类型。可以传递 null 或特定类型的值,结果相同。如示例所建议,将这些函数应用于表列或函数自变量比将其应用于硬连接类型名称更为常见。