这篇文章主要介绍了MyBatis-Plus的物理删除和逻辑删除怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
物理删除:真实删除,将数据从数据库中删除,删除后查询不到被删除的数据
逻辑删除:假删除,方便删除之后的数据恢复
在表中添加一个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); }
先添加测试数据
再测试逻辑删除
感谢你能够认真阅读完这篇文章,希望小编分享的“MyBatis-Plus的物理删除和逻辑删除怎么用”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。