暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

【翻译PG】枚举支持函数

原创 seagull 2023-03-28
195


9.10. 枚举支持函数


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

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


表 9.33. 枚举支持函数

函数 描述 例子 例子结果
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外, 这些函数忽略传递给它们的具体值,它们只关心声明的数据类型。 空值或类型的一个特定值可以通过,并得到相同的结果。这些函数更多地被用于一个表列或函数参数,而不是一个硬写的类型名,如例子中所建议。


「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论