PostgreSQL中可通过CREATE TYPE创建复合、枚举和范围类型。1. 复合类型如address_type用于表字段;2. 枚举类型order_status约束取值;3. 范围类型age_range表示区间;支持dT+查看,DROP TYPE删除,ALTER TYPE扩展值,提升数据完整性与复用性。

在 PostgreSQL 中创建自定义类型(也称为用户定义类型,UDT)可以通过多种方式实现,包括基础的 CREATE TYPE 命令来定义复合类型、枚举类型、范围类型或通过 C 语言扩展创建更复杂的底层类型。本文聚焦于使用 SQL 命令创建常见类型的自定义类型,适合大多数业务场景。
创建复合类型(Composite Type)
复合类型类似于结构体,由多个字段组成,常用于函数返回值或表字段定义。
示例:定义一个表示地址的复合类型
CREATE TYPE address_type AS ( street text, city text, zipcode text);
创建后,可在表中使用:
CREATE TABLE users ( id serial PRIMARY KEY, name text, addr address_type);
创建枚举类型(Enum Type)
枚举类型适用于有限集合的取值,如状态、类别等,提升数据完整性。
示例:定义订单状态枚举
CREATE TYPE order_status AS ENUM ( 'pending', 'shipped', 'delivered', 'cancelled');
在表中使用枚举类型:
SciMaster
全球首个通用型科研AI智能体
156 查看详情
CREATE TABLE orders ( id serial PRIMARY KEY, status order_status DEFAULT 'pending', created_at timestamp DEFAULT NOW());
创建范围类型(Range Type)
范围类型用于表示一个值的区间,PostgreSQL 内建支持数值、时间等范围,也可自定义。
示例:基于整数创建年龄范围类型
CREATE TYPE age_range AS RANGE ( subtype = integer, collation = "default", subtype_operator_class = integer_ops);
使用该类型定义表字段:
CREATE TABLE age_groups ( group_name text, age_span age_range);
使用自定义类型的小贴士
查看已存在的类型:dT+ 可列出数据库中所有用户定义类型 删除类型:DROP TYPE [IF EXISTS] type_name;,若被引用需加 CASCADE 在函数中使用复合类型作为参数或返回值,可封装复杂逻辑 枚举值可后续添加:ALTER TYPE order_status ADD VALUE 'refunded';
基本上就这些。PostgreSQL 的自定义类型功能强大且灵活,合理使用能显著提升数据库设计的表达力和安全性。不复杂但容易忽略的是命名规范与类型复用,建议统一管理类型定义,避免冗余。
以上就是postgresql自定义类型如何创建_postgresqludt实现指导的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1084306.html
微信扫一扫
支付宝扫一扫