Skip to content

9.10. 枚举支持函数#

对于枚举类型(在第 8.7 节中描述),有几个函数允许在不硬编码枚举类型的特定值的情况下进行更简洁的编程。这些函数在表 9.35中列出。示例假设枚举类型创建为

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

表 9.35. 枚举支持函数

函数

说明

示例

enum_first ( anyenum ) → anyenum

返回输入枚举类型的第一个值。

enum_first(null::rainbow)red

enum_last ( anyenum ) → anyenum

返回输入枚举类型的最后一个值。

enum_last(null::rainbow)purple

enum_range ( anyenum ) → anyarray

以有序数组形式返回输入枚举类型的所有值。

enum_range(null::rainbow){red,orange,yellow,​green,blue,purple}

enum_range ( anyenum, anyenum ) → anyarray

以有序数组形式返回两个给定枚举值之间的范围。这些值必须来自同一枚举类型。如果第一个参数为 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 或类型的特定值,结果相同。将这些函数应用于表列或函数参数比应用于示例中使用的硬连线类型名称更常见。