7. MyBatisPlus实现逻辑删除

MyBatisPlus实现逻辑删除

  • 物理删除:真实删除,将对应数据从数据库中删除,之后查询不到此条被删除数据。
  • 逻辑删除:假删除,将对应数据中代表是否被删除字段状态修改为“被删除状态”,之后在数据库中仍旧能看到此条数据记录。

在这里插入图片描述

1. 数据库中添加 deleted字段

ALTER TABLE `user` ADD COLUMN `deleted` boolean

在这里插入图片描述

2. 实体类添加deleted字段

  • 并加上 @TableLogic 注解@TableField(fill = FieldFill.INSERT) 注解
    @TableLogic
    @TableField(fill = FieldFill.INSERT)
    private Boolean deleted;

3. 元对象处理器接口添加deleted的insert默认值

/**
 * @Date 2020/4/10 12:49
 * @Version 10.21
 * @Author DuanChaojie
 */
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
         // ......
        this.setFieldValByName("deleted",0,metaObject);

    }

    @Override
    public void updateFill(MetaObject metaObject) {
        // ......
    }
}

4. application.properties 加入配置

此为默认值,如果你的默认值和mp默认的一样,该配置可无

mybatis-plus.global-config.db-config.logic-delete-value=1
mybatis-plus.global-config.db-config.logic-not-delete-value=0

5. 在 MybatisPlusConfig 中注册 Bean

    @Bean
    public ISqlInjector sqlInjector(){
        return new LogicSqlInjector();
    }

6. 测试逻辑删除

  • 测试后发现,数据并没有被删除,deleted字段的值由0变成了1
  • 测试后分析打印的sql语句,是一条update
  • **注意:**被删除数据的deleted 字段的值必须是 0,才能被选取出来执行逻辑删除的操作
    /**
     * 测试逻辑删除
     */
    @Test
    public void testLogicDelete(){
        int result = userMapper.deleteById(4L);
        System.out.println("result = " + result);
    }

7. 测试逻辑删除后的查询

  • MyBatisPlus中查询操作也会自动添加逻辑删除字段的判断
  • 测试后分析打印的sql语句,包含 WHERE deleted=0
  • SELECT id,name,age,email,create_time,update_time,deleted FROM user WHERE deleted=0
    /**
     * 测试 逻辑删除后的查询:不包括被逻辑删除的记录
     */
    @Test
    public void testLogicDeleteSelect(){
        User user = new User();
        List<User> users = userMapper.selectList(null);
        users.forEach(System.out::println);
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值