逻辑删除支持
逻辑删除是一种优雅的数据管理策略,它通过在数据库中标记记录为“已删除”而非物理删除,来保留数据的历史痕迹,同时确保查询结果的整洁性。MyBatis-Plus 提供了便捷的逻辑删除支持,使得这一策略的实施变得简单高效。
逻辑删除的工作原理
MyBatis-Plus 的逻辑删除功能会在执行数据库操作时自动处理逻辑删除字段。以下是它的工作方式:
- 插入:逻辑删除字段的值不受限制。
- 查找:自动添加条件,过滤掉标记为已删除的记录。
- 更新:防止更新已删除的记录。
- 删除:将删除操作转换为更新操作,标记记录为已删除。
例如:
- 删除:
update user set deleted=1 where id = 1 and deleted=0
- 查找:
select id,name,deleted from user where deleted=0
支持的数据类型
逻辑删除字段支持所有数据类型,但推荐使用 Integer
、Boolean
或 LocalDateTime
。
如果使用 datetime
类型,可以配置逻辑未删除值为 null
(长度为4的字符串,在yaml中需使用转义符(单引号)包裹),已删除值可以使用函数如 now()
来获取当前时间。
如果使用 bigint
类型,可以配置逻辑未删除值为 0,已删除值可以使用函数如 UNIX_TIMESTAMP()
来获取当前时间戳作为删除标识。适合用于将删除字段作为唯一索引组成列,可以多次逻辑删除.
使用方法
步骤 1: 配置全局逻辑删除属性
在 application.yml
中配置 MyBatis-Plus 的全局逻辑删除属性:
步骤 2: 在实体类中使用 @TableLogic
注解
在实体类中,对应数据库表的逻辑删除字段上添加 @TableLogic
注解:
常见问题解答
1. 如何处理插入操作?
- 方法一:在数据库中为逻辑删除字段设置默认值。
- 方法二:在插入数据前手动设置逻辑删除字段的值。
- 方法三:使用 MyBatis-Plus 的自动填充功能。
2. 删除接口自动填充功能失效怎么办?
- 方法一:使用
deleteById
方法。 - 方法二:使用
update
方法,并使用UpdateWrapper.set(column, value)
。 - 方法三:使用
update
方法,并使用UpdateWrapper.setSql("column=value")
。 - 方法四:使用 Sql 注入器注入
com.baomidou.mybatisplus.extension.injector.methods.LogicDeleteByIdWithFill
并使用(3.5.0版本已废弃,推荐使用deleteById)。
通过以上步骤,你可以轻松地在 MyBatis-Plus 中实现逻辑删除功能,提高数据管理的灵活性和安全性。