Mybatis plus逻辑删除失败的BUG操作
程序员文章站
2022-06-24 22:24:30
开发调试的时候发现mybatis plus的逻辑删除失效了,看了下配置文件发现没有问题,通过查看以下源码发现逻辑删除需要注入的bean,查看这个bean的源码如下查看其中一个实例的类的源码,如通过id...
开发调试的时候发现mybatis plus的逻辑删除失效了,看了下配置文件发现没有问题,通过查看以下源码发现
逻辑删除需要注入的bean,查看这个bean的源码如下
查看其中一个实例的类的源码,如通过id逻辑删除logicdeletebyid的源码,如下
mp在项目启动时预加载sql是通过tableinfo中logicdelete字段判断是否开启逻辑删除的。然后让我们来看看mp内部是如何判断是否开启逻辑删除的。
先看如下源码
大概就是讲实体类中的字段进行循环映射数据库字段并封装到tablefieldinfo类中,实体类信息封装到tableinfo中,在让我们来看看mp循环处理字段时候做了什么操作。
上图中的这一行代码,
让我们看看这行代码具体做了什么
现在已经很明确了,mp通过判断字段上是否有tablelogic注解来判断该实体类映射的表是否开启逻辑删除。但这一步是放到实体类所有的字段列表的循环中的,当逻辑删除字段在所有的字段中间而不是末尾的时候,判断逻辑删除的表示logicdelete会被覆盖为false,然后导致解析方法生成声明的时候判断为没有开启逻辑删除。
mp已经更新了这个错误,在设置logicdelete时会先判断原来的删除标识是否为true,否则保持原来的初始值false。
补充知识:分布式 mybatis-plus 逻辑删除不生效 升级后org.mybatis.logging.loggerfactory报错
解决方案:
第一步:升级mybatisplus版本到3.2.0
第二步:多添加一个扩展包
<dependency> <groupid>com.baomidou</groupid> <artifactid>mybatis-plus-extension</artifactid> <version>3.2.0</version> </dependency>
以上这篇mybatis plus逻辑删除失败的bug操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。