🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
# 9.10\. 支持枚举函数 对于枚举类型(描述在[Section 8.7](#calibre_link-825)), 有一些函数允许简洁的编写没有硬编码特定的枚举类型值。 这些列在[Table 9-29](#calibre_link-2217)。像下面的创建枚举类型的例子: ``` CREATE TYPE rainbow AS ENUM ('red', 'orange', 'yellow', 'green', 'blue', 'purple'); ``` **Table 9-29\. 支持枚举函数** | 函数 | 描述 | 示例 | 结果 | | --- | --- | --- | --- | | `enum_first(anyenum)` | 返回输入枚举类型的第一个值 | `enum_first(null::rainbow)` | `red` | | `enum_last(anyenum)` | 返回输入枚举类型的最后一个值 | `enum_last(null::rainbow)` | `purple` | | `enum_range(anyenum)` | 以一个有序的数组的形式返回输入枚举类型的所有值 | `enum_range(null::rainbow)` | `{red,orange,yellow,green,blue,purple}` | | `enum_range(anyenum, anyenum)` | 返回在给定两个枚举值之间的范围,作为一个有序数组。该值必须是相同的枚举类型。 如果第一个参数为空,其结果将从枚举类型的第一个值开始。 如果第二参数为空, 其结果将以枚举类型的最后一个值结束。 | `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或一个特定类型的值可以通过,得到相同的结果。 更常见于这些功能应用于表列或函数的参数而不是一个硬性的类型名称, 就像例子中建议的那样。