Mybatisplus中出现逻辑删除失败的原因有哪些-创新互联

本篇文章为大家展示了Mybatis plus中出现逻辑删除失败的原因有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

10年积累的成都做网站、成都网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有汉川免费网站建设让你可以放心的选择与我们合作。

开发调试的时候发现Mybatis Plus的逻辑删除失效了,看了下配置文件发现没有问题,通过查看以下源码发现

Mybatis plus中出现逻辑删除失败的原因有哪些

逻辑删除需要注入的bean,查看这个bean的源码如下

Mybatis plus中出现逻辑删除失败的原因有哪些

查看其中一个实例的类的源码,如通过ID逻辑删除LogicDeleteById的源码,如下

Mybatis plus中出现逻辑删除失败的原因有哪些

mp在项目启动时预加载SQL是通过TableInfo中logicDelete字段判断是否开启逻辑删除的。然后让我们来看看mp内部是如何判断是否开启逻辑删除的。

先看如下源码

Mybatis plus中出现逻辑删除失败的原因有哪些

大概就是讲实体类中的字段进行循环映射数据库字段并封装到TableFieldInfo类中,实体类信息封装到TableInfo中,在让我们来看看MP循环处理字段时候做了什么操作。

Mybatis plus中出现逻辑删除失败的原因有哪些

上图中的这一行代码,

Mybatis plus中出现逻辑删除失败的原因有哪些

让我们看看这行代码具体做了什么

Mybatis plus中出现逻辑删除失败的原因有哪些

现在已经很明确了,mp通过判断字段上是否有TableLogic注解来判断该实体类映射的表是否开启逻辑删除。但这一步是放到实体类所有的字段列表的循环中的,当逻辑删除字段在所有的字段中间而不是末尾的时候,判断逻辑删除的表示logicDelete会被覆盖为false,然后导致解析方法生成声明的时候判断为没有开启逻辑删除。

Mybatis plus中出现逻辑删除失败的原因有哪些

mp已经更新了这个错误,在设置logicDelete时会先判断原来的删除标识是否为true,否则保持原来的初始值false。

补充知识:分布式 mybatis-plus 逻辑删除不生效 升级后org.mybatis.logging.LoggerFactory报错

解决方案:

第一步:升级mybatisplus版本到3.2.0

第二步:多添加一个扩展包


        com.baomidou
        mybatis-plus-extension
        3.2.0
      

上述内容就是Mybatis plus中出现逻辑删除失败的原因有哪些,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


分享标题:Mybatisplus中出现逻辑删除失败的原因有哪些-创新互联
网站路径:http://myzitong.com/article/dgdpoc.html