mybatisPlus填坑之逻辑删除的实现

网友投稿 1077 2022-11-03

mybatisPlus填坑之逻辑删除的实现

mybatisPlus填坑之逻辑删除的实现

网上大部分的关于mybatisPlus的逻辑删除的配置介绍都是有问题的,原因可能是官网已经做了更新!!!错误如图:

正确的配置是:

SpringBoot 配置方式:

application.yml 加入配置(如果你的默认值和mp默认的一样,该配置可无):yml文件(区别是多了一个路径db-config,同学们细看了)

mybatis-plus:

global-config:

db-chttp://onfig:

logic-delete-value: 1 # 逻辑已删除值(默认为 1)

logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)

对于逻辑删除-的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;

@Configuration

public class MyBatisPlusConfiguration {

@Bean

public ISqlInjector sqlInjector() {

return new LogicSqlInjector();

}

}

实体类字段上加上@TableLogic注解

@TableLogic

private Integer deleted;

效果: 使用mp自带方法删除和查找都会附带逻辑删除功能 (自己写的xml不会)

example

删除时 update user set deleted=1 where id =1 and deleted=0

查找时 select * from user where deleted=0

附件说明

逻辑删除是为了方便数据恢复和保护数据本身价值等等的一种方案,但实际就是删除。如果你需要再查出来就不应使用逻辑删除,而是以一个状态去表示。

如: 员工离职,账号被锁定等都应该是一个状态字段,此种场景不应使用逻辑删除。

若确需查找删除数据,如老板需要查看历史所有数据的统计汇总信息,请单独手写sql。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:基本算法练习——接金币
下一篇:基本算法练习——上台阶
相关文章

 发表评论

暂时没有评论,来抢沙发吧~