Mybatis plus中如何解决逻辑删除功能失效的问题?

2026-04-30 08:071阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计504个文字,预计阅读时间需要3分钟。

Mybatis plus中如何解决逻辑删除功能失效的问题?

开发调试时发现Mybatis-Plus的逻辑删除失效了,检查了下配置文件发现没有问题。通过查看以下源码发现,逻辑删除需要注入特定的bean,查看这个bean的源码以及其中实例化的一个类的源码如下:

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

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

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

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

先看如下源码

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

上图中的这一行代码,

Mybatis plus中如何解决逻辑删除功能失效的问题?

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

现在已经很明确了,mp通过判断字段上是否有TableLogic注解来判断该实体类映射的表是否开启逻辑删除。

阅读全文
标签:bug操作

本文共计504个文字,预计阅读时间需要3分钟。

Mybatis plus中如何解决逻辑删除功能失效的问题?

开发调试时发现Mybatis-Plus的逻辑删除失效了,检查了下配置文件发现没有问题。通过查看以下源码发现,逻辑删除需要注入特定的bean,查看这个bean的源码以及其中实例化的一个类的源码如下:

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

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

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

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

先看如下源码

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

上图中的这一行代码,

Mybatis plus中如何解决逻辑删除功能失效的问题?

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

现在已经很明确了,mp通过判断字段上是否有TableLogic注解来判断该实体类映射的表是否开启逻辑删除。

阅读全文
标签:bug操作