这是我第一次写简书,java新手,昨天突然在自己写练习项目的时候发现,枚举添加到数据库,使用了MybatisPlus添加不了(以前一直使用的他自己封装的添加方法),下面这是我的解决办法;
这是MybatisPlus定义的枚举接口MP推荐使用这个枚举接口进行自动注入,但是再对象中有枚举进行储存的时候(使用MP自己封装的insert方法不用这样),会出现类型转换不了,那是因为在MP中实现的继承BaseEnumHanlder类的时候只是将Serialiable获取到(parameter.getValue()这个方法),并没有在该方法中实现转换为我们想要的类型;
MybatisPlus实现的set方法比方说我的枚举类型定义为这样:
示例枚举(value,desc)在储存到数据的时候,我们肯定只存value到数据库中,由于Mybatis的接口返回的是Serializable,它自己封装的添加方法是怎么转化的,我还没有找到,所以就只能自己重写一个;
在重写的时候,只需要重写setNonNullParameter这个方法就行,其他的方法在MybatisPlus中已经实现好了的。
在添加的枚举属性后面直接加上我们实现的TypeHandler类如果不使用IEnum接口,自己定义接口的话,请忽略我的做法,但是在接收数据库中的数据封装成对象的时候,要在对象中枚举属性<result typeHandler=对应的EnumHanlder类>,不然会出现装配类型不匹配;
最后不要忘记使用jackson的解析Json字符串,不然传到前台就是枚举的名字,而不是描述了。
这是第一种,还有一种实现方式(同事给我说的一种),就是将枚举的字段(value,desc)全部添加到实体对象中,像这样:
然后再在枚举中添加自定义方法,getDescByValue(Integer value):
然后再利用MP的注解@TableField(exist= false),取消在数据库中的字段,在status(也就是枚举中value值)的set方法中添加setDesc(TestType.getDescByValue(status));这样就能在数据库的添加或者查询都能得到我们想要的东西;
如果有什么不对的地方,或者更好的处理方式,可以留言告诉我,互相学习。
网友评论