当前位置: 首页 > news >正文

MyBatis-Plus通用枚举

MyBatis-Plus通用枚举

  • MyBatis-Plus通用枚举是什么
  • 示例详解

MyBatis-Plus通用枚举是什么

MyBatis-Plus 通用枚举是基于 MyBatis 的类型处理器 TypeHandler 扩展实现的标准化、通用化枚举适配方案,核心定位是解决代码层枚举语义化与数据库层编码轻量化的映射问题。

它通过注解(@EnumValue)或接口(IEnum)约定枚举值与数据库存储编码的映射规则,结合枚举包扫描机制,实现枚举类型与数据库字段编码的无侵入式自动化双向转换,无需开发者编写手动转换逻辑,且一套规则可统一适配所有符合约定的枚举类。

示例详解

下面通过示例对MyBatis-Plus通用枚举的执行流程进行详细介绍

数据库表添加字段sex

创建通用枚举类型
用 @EnumValue 标注数据库存储的枚举编码字段

@GetterpublicenumSexEnum{MALE(1,"男"),FEMALE(2,"女");@EnumValueprivateIntegersex;// 核心字段privateStringsexName;// 业务描述字段SexEnum(Integersex,StringsexName){this.sex=sex;this.sexName=sexName;}}

MyBatis-Plus 通用枚举类的核心构成要素如下:
首先需通过 @Getter 注解(或手动编写)为所有私有字段提供 Getter 方法,满足 MP 反射获取字段值的基础要求;其次必须定义由 @EnumValue 注解标注的数据库映射核心字段,该字段是 MP 实现枚举和数据库编码双向转换的唯一依据,写库时反射获取其编码值写入数据库,读库时依据编码值反向匹配枚举项;可写业务描述字段(非 MP 强制要求,可提升枚举的业务语义可读性);此外需声明具体枚举项,每个枚举项对应一组数据库编码值和业务描述值,枚举项将抽象的业务状态转化为代码中语义明确、可直接引用的实例;最后通过私有构造器完成核心字段与业务描述字段的初始化。

在 MyBatis-Plus 早期版本中,实现通用枚举的主流方式是让枚举类实现 IEnum 接口,且需指定接口泛型(泛型类型与数据库编码字段类型一致),并强制重写 getValue() 方法,下面是具体代码

@GetterpublicenumSexEnum1implementsIEnum<Integer>{MALE(1,"男"),FEMALE(2,"女");privateIntegersex;privateStringsexName;SexEnum1(Integersex,StringsexName){this.sex=sex;this.sexName=sexName;}@OverridepublicIntegergetValue(){returnthis.sex;}}

新版仍兼容该方式,若枚举同时标注 @EnumValue 和实现 IEnum 接口,@EnumValue 的优先级更高

实体类

@Data@NoArgsConstructor@AllArgsConstructorpublicclassUser{privateLongid;privateStringname;privateIntegerage;privateStringemail;// 枚举privateSexEnumsex;}

实体类中的 sex 属性无需定义为数据库存储的编码类型,可直接声明为自定义的通用枚举类型,MyBatis-Plus 框架会自动完成枚举类型与数据库编码之间的双向转换

type-enums-package 是 MyBatis-Plus 配置文件中用于指定通用枚举类扫描包路径的配置项。MP 启动阶段会扫描该路径下所有符合通用枚举规范的枚举类,一方面自动识别枚举类中基于@EnumValue / IEnum 定义的映射规则,另一方面为这些枚举类自动绑定内置的 MybatisEnumTypeHandler 类型处理器,而 MybatisEnumTypeHandler 作为核心组件,支撑了通用枚举与数据库编码之间的自动双向转换能力。

测试代码

@AutowiredprivateUserMapperuserMapper;@TestpublicvoidtestSexEnum(){Useruser=newUser();user.setName("Enum");user.setAge(20);user.setEmail("test@enum.com");user.setSex(SexEnum.MALE);userMapper.insert(user);System.out.println(user.getSex());// 获取枚举实例System.out.println(user.getSex().getSex());// 获取数据库存储的编码值System.out.println(user.getSex().getSexName());// 获取业务描述}

执行user.setSex(SexEnum.MALE);MP 会通过 MybatisEnumTypeHandler 自动将枚举项 SexEnum.MALE 转换为其 @EnumValue 标注的编码值 1 写入数据库。

user.getSex() 获取 SexEnum.MALE 枚举实例
user.getSex().getSex() 获取数据库存储的编码值
user.getSex().getSexName() 获取业务描述

执行结果如图:


http://www.jsqmd.com/news/74661/

相关文章:

  • Wan2.2-T2V-A14B实现高质量运动过渡的算法原理揭秘
  • Wan2.2-T2V-A14B模型未来是否会开放更多训练细节?
  • League Akari:解放双手的智能英雄联盟游戏利器
  • 大麦网抢票脚本实战手册:从零到精通的技术指南
  • Windows远程桌面多用户并发连接终极指南:从零到精通的完整教程
  • Vue滑块组件终极指南:从基础到高级实战应用
  • 数据资产治理:构建企业级数据管理体系的7个关键步骤
  • 如何在Linux上通过Vulkan实现Direct3D游戏性能提升300%
  • 3步搞定Zotero-Better-Notes字体大小自定义:告别模糊阅读体验
  • 270M参数撬动百亿市场:Gemma 3微型模型如何重塑边缘AI格局
  • DriverStore Explorer:Windows驱动管理的终极解决方案
  • 百度网盘下载神器:2025年免费极速下载终极指南
  • Wan2.2-T2V-A14B模型在视频内容审核自动化中的反向应用
  • Godot游戏资源解包终极指南:3步快速提取.pck文件
  • Bypass Paywalls Clean:终极内容解锁工具快速上手指南
  • 【微实验】聚类算法之——均值漂移(附MATLAB实现)
  • VibeVoice-Large-Q8:选择性8位量化技术优化语音模型存储与性能难题
  • 240亿参数重塑企业AI:Magistral 1.2开启本地化多模态部署新纪元
  • DREAMVFIA i18n Manager - 国际化管理平台完整项目代码数据包
  • DREAMVFIA WebScraper SDK - 企业级Web抓取开发套件项目开源完整代码数据包
  • 70亿参数重塑企业AI格局:IBM Granite-4.0-H-Tiny开启本地化部署新纪元
  • Wan2.2-T2V-A14B在短视频平台内容批量生成的应用
  • 如何快速掌握DBeaver:数据库管理与开发的终极开源工具 [特殊字符]
  • Joy-Con Toolkit 终极配置手册:从入门到精通的手柄管理艺术
  • 基于vue的乡镇普法宣传系统法律知识咨询服务系统
  • 大数据基于spark的旅游路线推荐系统 爬虫可视化系统
  • YimMenu DLL注入终极指南:从零基础到精通掌握
  • 金仓数据库Oracle模式系统配置详解与实践指南
  • 21、企业资源管理中的网络服务与资源管理基础设施
  • Wan2.2-T2V-A14B如何处理多语言混合输入的文本提示?