MyBatis Plus逻辑删除的使用
问题背景
逻辑删除经常使用。使用场景:可以进行数据恢复
- 物理删除:真实删除,将对应数据从数据库中删除,之后查询不到此条被删除的数据
- 逻辑删除:假删除,将对应数据中代表是否被删除字段的状态修改为“被删除状态”,之后在数据库中仍旧能看到此条数据记录
逻辑删除
2 实体类中添加逻辑删除属性,实体类没有使用isDeleted,可能会跟其他框架逻辑冲突,所以禁止使用is开头
- 默认1为已经被逻辑删除了,0没有被删除
@TableLogic
@TableField(value = "is_deleted")
private Integer deleted;
3 删除:删除功能被转变为更新功能
-- 实际执行的SQL
update user set is_deleted=1 where id = 1 and is_deleted=0
3 查询被逻辑删除的数据默认不会被查询
-- 实际执行的SQL
update user set is_deleted=1 where id = 1 and is_deleted=0
总结
如果项目中被逻辑删除的数据,不需要把is_deleted恢复为0继续使用的话,那么久使用这个注解,如果还需要恢复到0的话,那么不推荐使用这个注解,因为使用了这个注解项目里面被整体限制了,如上面的查询语句一样,每次都会附带where is_deleted=0,那么就没办法读到is_deleted=1的语句进行修改
作为程序员第 227 篇文章,每次写一句歌词记录一下,看看人生有几首歌的时间,wahahaha …
Lyric: 哪里都是你
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/110648.html