数据库中的数据删除会分为两种:物理删除 和 逻辑删除
物理删除
物理删除就是我们删除数据库中的一条数据时,数据会真的被删除
逻辑删除
逻辑删除指的是我们删除一条数据时,数据不会在数据库中消息,逻辑删除是我们现在开发中经常使用到的一种删除
(1)首先我们需要在实体类和数据表中添加一个逻辑删除字段deleted,默认为0
数据库(这里以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的数据
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://lebron.blog.csdn.net/article/details/124964442
内容来源于网络,如有侵权,请联系作者删除!