MyBatisPlus @TableLogic实现全局自动逻辑删除

一、背景

有一天,小王在编写代码时实现了一个删除操作,但由于测试场景覆盖不全,上线后不慎删除了系统中的部分业务数据。幸运的是,系统已经开启了binlog日志功能,使得我们能够根据日志来恢复这些误删的数据。这一事故成为了一个深刻的教训,在部门会议上,我们决定对后续的所有表数据操作采取更加谨慎的措施。大林子提出了一个建议,他认为我们应该默认设置全局自动逻辑删除,以避免物理删除数据的风险。由于我们使用的Mybatis-Plus框架提供了简便的逻辑删除功能,这个建议得到了大家的认可。因此,这个任务自然而然地交给了大林子来负责实施。

二、实现

@TableLogic这个注释是专门为在数据库实体中实现逻辑删除功能而设计的。逻辑删除意味着当您想要"删除"一条记录时,不是从数据库中物理地删除它,而是通过更新该记录中的特定列(通常称为deleted、is_deleted或类似的列)将该记录标记为已删除。

MyBatisPlus支持逻辑删除功能,可以通过设置全局配置或者在实体类上添加注解来实现。一旦启用了逻辑删除功能,MyBatisPlus在执行删除操作时,并不会真正从数据库中物理删除数据,而是通过更新一个标记字段(如del_flag)来表示这条数据已被逻辑删除。

在MyBatisPlus的配置中开启逻辑删除功能,并指定逻辑未删除的值(如del_flag=0)。这样,在使用MyBatisPlus的查询方法时,除非特别指定,逻辑删除的数据会被自动过滤。

java 复制代码
@Data
@EqualsAndHashCode(callSuper false)
@Accessors(chain true)
public class TbTest extends BaseEntity implements Serializable{
	//具体字段省略。。。
}
java 复制代码
@Data
public class BaseEntity{

/**
*删除标志
*/
@TableLogic
private Integer delFlag;

}
相关推荐
海盗12342 分钟前
C#中的IEqualityComparer<T>使用
开发语言·c#
小新同学^O^5 分钟前
简单学习 --> TCP协议
java·网络·tcp
江公望11 分钟前
Qt QSharedPointer用法,10分钟讲清楚
开发语言·qt
月落归舟17 分钟前
深入理解Java适配器模式,彻底搞懂设计思想
java·开发语言·适配器模式
Mr_pyx18 分钟前
【LeetHOT100】二叉树的中序遍历——Java多解法详解
java·开发语言·深度优先
jay神29 分钟前
基于SpringBoot的宠物生命周期信息管理系统
java·数据库·spring boot·后端·web开发·宠物·管理系统
万亿少女的梦1681 小时前
基于SpringBoot的在线考试管理系统设计与实现
java·spring boot·后端
m0_738120721 小时前
渗透测试——Djinn1靶场详细渗透提权过程讲解(绕过黑名单限制,命令执行反弹shell,pyc反编译,代码白盒分析,python沙盒逃逸)
开发语言·python·php
一勺菠萝丶1 小时前
如何在 Linux 服务器上使用 Speedtest 官方 CLI 测试带宽(小白教程)
java·服务器·前端
web守墓人1 小时前
【go语言】go语言实现go-torch, 完成Lenet-5的搭建,训练,以及pth和onnx模型导出
开发语言·后端·golang