枚举支持函数#

9.10. 枚举支持函数

对于枚举类型(在第 8.7 节中描述), 有一些函数允许更清洁的编码,而不需要为一个枚举类型硬写特定的值。它们被列在表 9.33中。本例假定一个枚举类型被创建为:

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

表 9.33. 枚举支持函数

函数

描述

例子

例子结果

enum_fi rst(anyenum)

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

` enum_first(nu ll::rainbow)`

red

enum_l ast(anyenum)

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

enum_last(nu ll::rainbow)

purple

enum_ra nge(anyenum)

将 输入枚举类型的 所有值作为一个 有序的数组返回

` enum_range(nu ll::rainbow)`

{red,orange ,yellow,green, blue,purple}

en um_range(anyen um, anyenum)

以一个数组返 回在给定两个枚 举值之间的范围 。值必须来自相 同的枚举类型。 如果第一个 参数为空,其结 果将从枚举类型 的第一个值开始 。如果第二参数 为空,其结果将 以枚举类型的最 后一个值结束。

enum_ra nge('orange':: rainbow, 'gree n'::rainbow)

{orange,y ellow,green}

enum_ran ge(NULL, 'gree n'::rainbow)

` {red,orange,y ellow,green}`

enum_rang e('orange'::ra inbow, NULL)

{orange ,yellow,green, blue,purple}

请注意,除了双参数形式的enum_range外, 这些函数忽略传递给它们的具体值,它们只关心声明的数据类型。 空值或类型的一个特定值可以通过,并得到相同的结果。这些函数更多地被用于一个表列或函数参数,而不是一个硬写的类型名,如例子中所建议。