2024年9月26日: PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:开发版
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3

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 或类型的特定值,结果相同。在表列或函数参数上应用这些函数比在示例中使用的硬编码类型名称更常见。

提交更正

如果您在文档中看到任何不正确的内容,与您对特定功能的体验不符,或者需要进一步澄清,请使用此表单报告文档问题。