MyBatis-Plus的物理删除和逻辑删除(使用场景)
时间:2022-02-09 09:24:06|栏目:JAVA代码|点击: 次
物理删除:真实删除,将数据从数据库中删除,删除后查询不到被删除的数据
逻辑删除:假删除,方便删除之后的数据恢复
在表中添加一个status字段,作为删除的标准,每次删除时,修改标志位,0代表没有删除,1代表删除
被删除记录的status字段被修改为“被删除状态”(1),删除后还可以查询到数据
逻辑删除的使用场景
1.需要进行数据恢复
2.有关联数据,不便删除
# mysql //测试逻辑删除 status int null default null
# 实体类 //实现逻辑删除 @TableLogic @TableField(fill=FieldFill.INSERT) //为了方便测试 private Integer status;
# MpConfig配置类
//status在添加时自动填充默认为0,未被删除状态(1是被删除状态)
this.setFieldValByName("status",0,metaObject);
# Test测试类
//先添加测试数据
@Test
public void testAdd(){
User user=new User();
//没有设置id属性主键自增长,但mybatis-plus会使用主键策略自动生成id值
user.setName("wangwu");
user.setAge(18);
user.setEmail("licy@163.com");
int insert=userMapper.insert(user);
System.out.println(insert);
}
//再测试逻辑删除
//在表中添加一个status字段,作为删除的标准,每次删除时,修改标志位,0代表没有删除,1代表删除
//UPDATE user SET status=1 WHERE id=? AND status=0 查询条件有一个status=0,即查询的都是没有被删除过的记录,被删除过的记录就不会被查询出来了
@Test
public void testDeleteByLogic(){
int rows=userMapper.deleteById(1441596779656179713L); //在做了逻辑删除的配置后,再使用id进行删除,执行的语句变成了修改id=?并且status为0的记录,如果status原来就是1(被删除过了),也不会再被删除,
System.out.println(rows);
}
先添加测试数据
再测试逻辑删除
上一篇:Java实现计算器设计
栏 目:JAVA代码
下一篇:spring data 连接mongodb的两种方式
本文标题:MyBatis-Plus的物理删除和逻辑删除(使用场景)
本文地址:http://www.codeinn.net/misctech/192861.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机






