mybatis plus实现逻辑删除

数据库中的数据删除会分为两种:物理删除 和 逻辑删除

物理删除

物理删除就是我们删除数据库中的一条数据时,数据会真的被删除

逻辑删除

逻辑删除指的是我们删除一条数据时,数据不会在数据库中消息,逻辑删除是我们现在开发中经常使用到的一种删除

(1)首先我们需要在实体类和数据表中添加一个逻辑删除字段deleted,默认为0

数据库(这里以user表为例)
这里以user表为例

实体类

在这里插入图片描述

我们可以在application.properties文件中进行deleted字段值修改,比如说,10代表没删除,11代表已经逻辑删除

mybatis-plus.global-config.db-config.logic-delete-value=11
mybatis-plus.global-config.db-config.logic-not-delete-value=10

默认的是0代表没删除,1代表已经逻辑删除,所以我们不配置也行

(2)在实体类上加上注解@TableLogic 表明该字段是逻辑删除字段

(3)在配置类中添加逻辑删除组件

	/**
     * 逻辑删除插件
     * @return
     */
    @Bean
    public ISqlInjector sqlInjector() {
        return new LogicSqlInjector();
    }

然后我们接着进行单元测试

 	@Test
    void delete(){
        int result = userMapper.deleteById(1293468101626593281L);
        System.out.println(result);
    }

执行代码之前我们可以在application.properties中添加:

#mybatis日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

主要用于在控制台打印sql语句

在日志中我们可以看一下它打印的sql语句,
在这里插入图片描述
底层其实就是update修改语句

我们在通过findAll方法来查询所有的user:

	@Test
    void findAll() {
        List<User> lists = userMapper.selectList(null);
        System.out.println(lists);

    }

在这里插入图片描述
此时它的sql语句是默认查询deleted=0的数据

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值