news 2026/5/25 9:43:59

MyBatis-Plus通用枚举

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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() 获取业务描述

执行结果如图:


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 12:48:02

数据资产治理:构建企业级数据管理体系的7个关键步骤

数据资产治理&#xff1a;构建企业级数据管理体系的7个关键步骤 关键词&#xff1a;数据治理、数据资产管理、企业级数据管理、数据质量、数据安全、数据战略、数据治理框架 摘要&#xff1a;在数字经济时代&#xff0c;数据已成为企业的核心战略资产。本文深入探讨了构建企业…

作者头像 李华
网站建设 2026/5/24 0:05:31

Wan2.2-T2V-A14B在智能制造工厂巡检动画中的细节刻画

Wan2.2-T2V-A14B在智能制造工厂巡检动画中的细节刻画引言&#xff1a;当文字开始“动”起来——工业可视化的新范式 在一座现代化的智能制造工厂里&#xff0c;每天都有成百上千条设备状态信息、巡检记录和报警日志被系统采集。但这些冷冰冰的数据背后&#xff0c;隐藏着一个长…

作者头像 李华
网站建设 2026/5/22 7:46:54

21、企业资源管理中的网络服务与资源管理基础设施

企业资源管理中的网络服务与资源管理基础设施 一、网络服务在 ERP 解决方案中的应用 1.1 电子商务与 ERP 的发展背景 电子商务技术为个人和企业带来了全新的合作与协作方式,催生了众多新的商业模式和就业机会。自 20 世纪 90 年代末以来,企业越来越依赖互联网和基于网络的…

作者头像 李华
网站建设 2026/5/20 11:55:59

ZenTimings完整使用指南:轻松掌握AMD Ryzen处理器的终极监控技巧

ZenTimings完整使用指南&#xff1a;轻松掌握AMD Ryzen处理器的终极监控技巧 【免费下载链接】ZenTimings 项目地址: https://gitcode.com/gh_mirrors/ze/ZenTimings 想要深入了解您的AMD Ryzen处理器运行状态吗&#xff1f;ZenTimings作为一款专为AMD平台设计的免费性…

作者头像 李华
网站建设 2026/5/22 13:24:37

241MB重塑边缘AI:谷歌Gemma 3 270M实现手机25次对话仅耗电0.75%

241MB重塑边缘AI&#xff1a;谷歌Gemma 3 270M实现手机25次对话仅耗电0.75% 【免费下载链接】gemma-3-270m-bnb-4bit 项目地址: https://ai.gitcode.com/hf_mirrors/unsloth/gemma-3-270m-bnb-4bit 导语 你还在为AI应用依赖云端、耗电卡顿而烦恼吗&#xff1f;谷歌Dee…

作者头像 李华
网站建设 2026/5/20 10:43:29

Beta 分布学习笔记

文章目录引言Beta 分布定义Beta 分布概率密度函数构造Beta 分布其他性质利用多次伯努利试验更新 Beta 分布前一段时间学习了 Dirichlet 分布&#xff0c;知道了这个分布其实本质上就是一种分布的分布。而今天写的Beta 分布本质上也是一种分布的分布。我是参考这篇文章学习的&am…

作者头像 李华