枚举支持函数
枚举类型函数¶
对于枚举类型, 本节所列函数允许使用更简洁的编码来操作,而不需要为一个枚举类型硬写特定的值。
本例假定一个枚举类型被创建为:
CREATE TYPE rainbow AS ENUM ('red', 'orange', 'yellow', 'green', 'blue', 'purple');
enum_first()
¶
- 语法
- enum_first(anyenum)
- 描述
- 返回输入枚举类型的第一个值
- 示例
- ``` sql
seaboxsql=# select enum_first(null::rainbow);
enum_first
red (1 row) ```
enum_last()
¶
- 语法
- enum_last(anyenum)
- 描述
- 返回输入枚举类型的最后一个值
- 示例
- ``` sql
seaboxsql=# select enum_last(null::rainbow);
enum_last
purple (1 row) ```
enum_range()
¶
- 语法
enum_range(anyenum[,anyenum])
- 描述
- 将输入枚举类型的所有值作为一个有序的数组返回. 参数为2个时,返回在给定两个枚举值之间的范围。值必须来自相同的枚举类型。如果第一个参数为空,其结果将从枚举类型的第一个值开始。如果第二参数为空,其结果将以枚举类型的最后一个值结束。
- 示例
-
``` sql seaboxsql=# select enum_range(null::rainbow); enum_range
{red,orange,yellow,green,blue,purple} (1 row)seaboxsql=# select enum_range('orange'::rainbow, 'green'::rainbow); enum_range
{orange,yellow,green} (1 row)
seaboxsql=# select enum_range(NULL, 'green'::rainbow); enum_range
{red,orange,yellow,green} (1 row)
seaboxsql=# select enum_range('orange'::rainbow, NULL); enum_range
{orange,yellow,green,blue,purple} (1 row) ```
注意
- 除了双参数形式的
enum_range
外, 这些函数忽略传递给它们的具体值,它们只关心声明的数据类型。空值或类型的一个特定值可以通过,并得到相同的结果。这些函数更多地被用于一个表列或函数参数,而不是一个硬写的类型名,如示例中所建议。