mybatisPlus填坑之逻辑删除的实现
网上大部分的关于mybatisPlus的逻辑删除的配置介绍都是有问题的,原因可能是官网已经做了更新!!!错误如图:
文章图片
正确的配置是:
SpringBoot 配置方式:
- application.yml 加入配置(如果你的默认值和mp默认的一样,该配置可无):
- yml文件(区别是多了一个路径db-config,同学们细看了)
mybatis-plus:global-config:db-config:logic-delete-value: 1 # 逻辑已删除值(默认为 1)logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
【mybatisPlus填坑之逻辑删除的实现】对于逻辑删除拦截器的bean的注入方式
import com.baomidou.mybatisplus.core.injector.ISqlInjector; import com.baomidou.mybatisplus.extension.injector.LogicSqlInjector; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configurationpublic class MyBatisPlusConfiguration { @Beanpublic ISqlInjector sqlInjector() {return new LogicSqlInjector(); }}
实体类字段上加上
@TableLogic
注解@TableLogicprivate Integer deleted;
效果: 使用mp自带方法删除和查找都会附带逻辑删除功能 (自己写的xml不会)
example删除时 update user set deleted=1 where id =1 and deleted=0查找时 select * from user where deleted=0
附件说明
- 逻辑删除是为了方便数据恢复和保护数据本身价值等等的一种方案,但实际就是删除。
- 如果你需要再查出来就不应使用逻辑删除,而是以一个状态去表示。
若确需查找删除数据,如老板需要查看历史所有数据的统计汇总信息,请单独手写sql。
到此这篇关于mybatisPlus填坑之逻辑删除的实现的文章就介绍到这了,更多相关mybatisPlus 逻辑删除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 历史上的今天|【历史上的今天】1 月 10 日(算法分析之父出生;史上最失败的世纪并购;含冤 50 年的计算机先驱)
- 【干货】TypeScript|【干货】TypeScript 实战之 extends、infer 与 dva type
- 算法|我工作第五年的学习与读书之法
- 数据分析|数据分析 - 基础原理 之 第三章(数据质量管理 - 第一节:数据质量评估)
- Python机器学习应用之基于决策树算法的分类预测篇
- python特效之字符成像详解
- 技能树-基础之章-数据结构-链表操作
- shiro|Shiro之@RequiresPermissions注解原理详解
- Vue|Vue 源码解读(8)—— 编译器 之 解析(上)
- 数据治理一体化实践之体系化建模