©
This document uses PHP Chinese website manual Release
对于枚举类型(描述在Section 8.7), 有一些函数允许简洁的编写没有特定的硬编码值的枚举类型。 这些列在Table 9-29。 像下面的创建枚举类型的例子:
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或一个特定的值
可以通过类型,得到相同的结果。这是较常见
这些功能适用于表列或函数的参数比一个硬性的类型名称,
作为建议的例子。