[toc]
MyBatisPlus实现逻辑删除
物理删除:
真实删除,将对应数据从数据库中删除,之后查询不到此条被删除数据。
逻辑删除:
假删除,将对应数据中代表是否被删除字段状态修改为“被删除状态”,之后在数据库中仍旧能看到此条数据记录。
![12 mp实现逻辑删除功能](/medias/mybatisplus/12 mp实现逻辑删除功能.png)
1. 数据库中添加 deleted字段
1
| ALTER TABLE `user` ADD COLUMN `deleted` boolean
|
2. 实体类添加deleted字段
- 并加上
@TableLogic 注解
和 @TableField(fill = FieldFill.INSERT)
注解
1 2 3
| @TableLogic @TableField(fill = FieldFill.INSERT) private Boolean deleted;
|
3. 元对象处理器接口添加deleted的insert默认值
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
|
@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默认的一样,该配置可无
1 2
| mybatis-plus.global-config.db-config.logic-delete-value=1 mybatis-plus.global-config.db-config.logic-not-delete-value=0
|
5. 在 MybatisPlusConfig
中注册 Bean
1 2 3 4
| @Bean public ISqlInjector sqlInjector(){ return new LogicSqlInjector(); }
|
6. 测试逻辑删除
- 测试后发现,数据并没有被删除,
deleted字段的值由0变成了1
测试后分析打印的sql语句,是一条update
- 注意:被删除数据的deleted 字段的值必须是 0,才能被选取出来执行逻辑删除的操作
1 2 3 4 5 6 7 8
|
@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
1 2 3 4 5 6 7 8 9
|
@Test public void testLogicDeleteSelect(){ User user = new User(); List<User> users = userMapper.selectList(null); users.forEach(System.out::println); }
|
☆