MyBatis-Plus通用枚举自动关联注入的实现
一、通用枚举
解决了繁琐的配置,让 mybatis 优雅的使用枚举属性!
按我的理解是维护在内存中且不易修改的轻量级字典。目前觉得这个功能的使用场景相对有限,但是如果有用到的话开箱即用也是很棒的。废话不多说,接下来让我们看一下它的实际效果吧。
一般搜索用户信息列表,列如用户有禁用和启用两个状态
@Data public class User implements Serializable { private static final long serialVersionUID = 1L; private BigInteger id; private String name; private String email; private Integer status; }
@GetMapping("/findById") public User findById(){ User user = userMapper.selectById(1); return user; }
查询结果:
如果前端接收到json数据后,需要的status字段属性值,不是1或者2,需要的是禁止或者启用的中文字,如何解决呢?
二、声明通用枚举属性
public enum StatusEnum implements IEnum<Integer> { DISABLE(1,"禁用"), ENABLE(2,"启用"); private final Integer status; //数据库存储字段 private final String desc; //返回的显示描述 StatusEnum(Integer status,String desc){ this.status = status; this.desc = desc; } @Override public Integer getValue() { return this.status; } @JsonValue public String getDesc(){ return this.desc; } }
实体属性使用枚举类型
@Data public class User implements Serializable { private static final long serialVersionUID = 1L; private BigInteger id; private String name; private String email; private StatusEnum status; }
三、配置扫描通用枚举
#mybatis-plus mybatis-plus: configuration: map-underscore-to-camel-case: true log-impl: org.apache.ibatis.logging.stdout.StdOutImpl mapper-locations: classpath:com/example/plus/mapper/xml/*.xml typeEnumsPackage: com.example.plus.enums
加入该配置:
typeEnumsPackage: com.example.plus.enums
测试:
四、注意、注意、注意
1、记得加上@JsonValue注解,序列化时只返回这一个字段的值。
2、配置扫描通用枚举可能3.0版本以前版本配置不一样,本列使用的是3.0以上版本
3、通用枚举无法正确取值,可能会报这样的错误
Caused by: java.lang.IllegalArgumentException: No enum constant
解决方式:
去除 pom.xml中:spring-boot-devtools依赖 ,该插件会导致很多问题
到此这篇关于MyBatis-Plus通用枚举自动关联注入的实现的文章就介绍到这了,更多相关MyBatis-Plus 枚举自动关联注入内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
简析Java中的util.concurrent.Future接口
这篇文章主要介绍了简析Java中的util.concurrent.Future接口,作者把future归结为在未来得到目标对象的占位符,需要的朋友可以参考下2015-07-07全面解析Spring Security 过滤器链的机制和特性
这篇文章主要介绍了Spring Security 过滤器链的机制和特性,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-07-07Springboot如何获取配置文件application.yml中自定义的变量并使用
这篇文章主要介绍了Springboot中获取配置文件(application.yml)中自定义的变量并使用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-09-09IDEA项目启动时Flyway数据库迁移中的checksum不匹配问题及最新解决方案
面对IDEA项目启动时报出的Flyway迁移校验和不匹配问题,核心在于保持迁移脚本的一致性、正确管理和理解Flyway的工作机制,本文介绍IDEA项目启动时Flyway数据库迁移中的checksum不匹配问题及最新解决方案,感兴趣的朋友一起看看吧2024-01-01
最新评论