美文网首页
MybatisPlus的枚举处理

MybatisPlus的枚举处理

作者: c97e4a46b0c0 | 来源:发表于2018-05-29 11:08 被阅读0次

    这是我第一次写简书,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));这样就能在数据库的添加或者查询都能得到我们想要的东西;

    如果有什么不对的地方,或者更好的处理方式,可以留言告诉我,互相学习。

    相关文章

      网友评论

          本文标题:MybatisPlus的枚举处理

          本文链接:https://www.haomeiwen.com/subject/moilcftx.html