首页
/ SeaORM 1.1.8版本发布:枚举字符串支持与Postgres网络类型增强

SeaORM 1.1.8版本发布:枚举字符串支持与Postgres网络类型增强

2025-06-07 05:36:01作者:盛欣凯Ernestine

SeaORM是一个现代化的Rust语言ORM框架,以其类型安全和异步支持著称。它提供了简洁的API来操作数据库,同时保持了高度的灵活性和性能。最新发布的1.1.8版本带来了几项重要改进,特别是对枚举字符串的支持和Postgres网络类型的增强。

枚举字符串支持

1.1.8版本引入了对枚举字符串的DeriveValueType派生宏支持。开发者现在可以方便地将枚举类型映射到数据库中的字符串列。

基本用法

#[derive(DeriveValueType)]
#[sea_orm(value_type = "String")]
pub enum Tag {
    Hard,
    Soft,
}

这种声明方式会自动为枚举类型实现必要的转换方法,使其能够与数据库中的字符串列无缝交互。

自定义转换方法

开发者还可以覆盖默认的字符串转换行为:

#[derive(DeriveValueType)]
#[sea_orm(value_type = "String", from_str = "Tag::from_str", to_str = "Tag::to_str")]
pub enum Tag {
    Color,
    Grey,
}

这种灵活性使得开发者可以根据业务需求定制枚举与字符串之间的转换逻辑。

Postgres网络类型支持

新版本增加了对PostgreSQL中网络类型的支持,包括IP地址和CIDR网络表示。

模型定义

#[derive(Clone, Debug, PartialEq, Eq, DeriveEntityModel)]
#[sea_orm(table_name = "host_network")]
pub struct Model {
    #[sea_orm(primary_key)]
    pub id: i32,
    pub ipaddress: IpNetwork,
    #[sea_orm(column_type = "Cidr")]
    pub network: IpNetwork,
}

数据库操作

开发者可以像操作其他类型一样操作网络类型:

host_network::ActiveModel {
    ipaddress: Set(IpNetwork::new(Ipv6Addr::new(..))),
    network: Set(IpNetwork::new(Ipv4Addr::new(..))),
    ..Default::default()
}

其他改进

  1. 增加了对PostgreSQL字节数组(bytea[])的支持
  2. 修复了PostgreSQL数组在扩展格式下的处理问题
  3. 内部优化:用标准库替代once_cell依赖

总结

SeaORM 1.1.8版本通过引入枚举字符串支持和Postgres网络类型增强,进一步提升了框架的实用性和灵活性。这些改进使得处理特定领域的数据类型变得更加简单直观,同时保持了SeaORM一贯的类型安全和性能优势。对于需要处理网络相关数据或复杂枚举类型的应用来说,这些新特性将大大简化开发工作。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
260
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
854
505
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
254
295
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
331
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
397
370
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
21
5