👉 这是一个或许对你有用的社群
🐱 一对一交流/面试小册/简历优化/求职解惑,欢迎加入「芋道快速开发平台」知识星球。下面是星球提供的部分资料:
《项目实战(视频)》:从书中学,往事中“练”
《互联网高频面试题》:面朝简历学习,春暖花开
《架构 x 系统设计》:摧枯拉朽,掌控面试高频场景题
《精进 Java 学习指南》:系统学习,互联网主流技术栈
《必读 Java 源码专栏》:知其然,知其所以然
👉这是一个或许对你有用的开源项目
国产 Star 破 10w+ 的开源项目,前端包括管理后台 + 微信小程序,后端支持单体和微服务架构。
功能涵盖 RBAC 权限、SaaS 多租户、数据权限、商城、支付、工作流、大屏报表、微信公众号、ERP、CRM、AI 大模型等等功能:
Boot 多模块架构:https://gitee.com/zhijiantianya/ruoyi-vue-pro
Cloud 微服务架构:https://gitee.com/zhijiantianya/yudao-cloud
视频教程:https://doc.iocoder.cn
【国内首批】支持 JDK 17/21 + SpringBoot 3.3、JDK 8/11 + Spring Boot 2.7 双版本
来源:blog.youkuaiyun.com/qq_43842093
介绍
@TableLogic
注解用于实现数据库的逻辑删除功能,它会影响insert
、select
、update
和delete
操作。当在字段上添加此注解并执行BaseMapper
的delete
方法时,实际执行的是更新操作,将删除字段设为特定值。
注解有两个参数:value
(默认值)和delval
(删除后的值)。在查询和更新时,会自动添加条件过滤已删除的数据。
基于 Spring Boot + MyBatis Plus + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能
项目地址:https://github.com/YunaiV/ruoyi-vue-pro
视频教程:https://doc.iocoder.cn/video/
1. @TableLogic注解
@TableLogic
:表示逻辑删除注解
效果:在字段上加上这个注解再执行BaseMapper
的删除方法时,删除方法就会变成修改
例:
实体类:
@TableLogic
private Integer del;
service层:
调用BaseMapper的deleteById(id);
执行是效果:
加@TableLogic的情况下
走 Update 表名 set 加注解的列=值 where del=值
不加@TableLogic的情况下
走 delete from 表名 where del=值
@TableLogic注解参数
value = "" 默认的原值
delval = "" 删除后的值
@TableLogic(value="原值",delval="改值")
基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能
项目地址:https://github.com/YunaiV/yudao-cloud
视频教程:https://doc.iocoder.cn/video/
2. 注解说明
@TableLogic
:用于实现数据库数据逻辑删除
注意,该注解只对自动注入的 sql 起效
3. @TableLogic 对于 CIUD 的限制
3.1 插入(insert)
不作限制
3.2 查找(select)
@TableLogic
注解将会在 select 语句的 where 条件添加条件,过滤掉已删除数据
且使用 wrapper.entity
生成的 where 条件会忽略该字段
SELECT` `user_id,``name``,sex,age,deleted ``FROM` `user` `WHERE` `user_id=1 ``AND` `deleted=``'0'
3.3 更新(update)
@TableLogic
注解将会在 update 语句的 where 条件后追加条件,防止更新到已删除数据
且使用 wrapper.entity
生成的 where条件会忽略该字段
update` `user` `set` `deleted=1 ``where` `id = 1 ``and` `deleted=0
3.4 删除(delete)
@TableLogic
注解会将 delete 语句转变为 update 语句
update` `user` `set` `deleted=1 ``where` `id = 1 ``and` `deleted=0
4. @TableLogic 字段类型支持说明:
支持所有数据类型(推荐使用 Integer
、Boolean
、LocalDateTime
)
如果数据库字段使用 datetime
,逻辑未删除值和已删除值支持配置为字符串 null,另一个值支持配置为函数来获取值如now()
附录:
逻辑删除是为了方便数据恢复和保护数据本身价值等等的一种方案,但实际就是删除。
如果你需要频繁查出来看就不应使用逻辑删除,而是以一个状态去表示。
5. 属性说明
5.1 value
用来指定逻辑未删除值,默认为空字符串
5.2 delval
用来指定逻辑删除值,默认为空字符串。
6. 在配置文件中实现
当然,你也可以不在 @TableLogic
注解中指定 value
和 delval
属性的值。使用全局逻辑删除配置信息,配置如下:
# application.yml
mybatis-plus:
global-config:
db-config:
# 全局逻辑删除的实体字段名 (since 3.3.0, 配置后可以忽略 @TableLogic 中的配置)
logic-delete-field: flag
# 逻辑已删除值(默认为 1)
logic-delete-value: 1
# 逻辑未删除值(默认为 0)
logic-not-delete-value: 0
7. 代码实践
7.1 代码实践过程
我们在 user
数据表中添加一个 deleted
字段。
如果该字段值为1,表示记录被删除。如果该字段值为0,表示记录未被删除
向 user 数据表添加 deleted 字段,sql 如下:
-- 添加一个 deleted 字段,实现逻辑删除
ALTER TABLE `user`
ADD COLUMN `deleted` varchar(1) NULL DEFAULT 0 COMMENT '是否删除(1-删除;0-未删除)';
创建 user 表的实体类
AnnotationUser7Bean
使用 @TableLogic
注解将 deleted
成员变量指定为逻辑删除字段
import com.baomidou.mybatisplus.annotation.*;
@TableName(value = "user")
public class AnnotationUser7Bean {
@TableId(value = "user_id", type = IdType.AUTO)
private int userId;
@TableField("name")
private String name;
@TableField("sex")
private String sex;
@TableField("age")
private Integer age;
@TableLogic(value = "0", delval = "1")
private String deleted;
// 忽略 getter 和 setter 方法
@Override
public String toString() {
return "UserBean{" +
"userId=" + userId +
", name='" + name + '\'' +
", sex='" + sex + '\'' +
", age=" + age +
", deleted=" + deleted +
'}';
}
}
上面代码中,使用 @TableLogic
注解将 deleted
成员变量指定为逻辑删除字段
@TableLogic(value = "0", delval = "1")
private String deleted;
客户端代码,先查询用户ID为1的用户是否存在
如果存在,则删除该用户信息
然后,查询用户ID小于10的用户信息
package com.hxstrive.mybatis_plus.simple_mapper.annotation;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.hxstrive.mybatis_plus.mapper.AnnotationUser7Mapper;
import com.hxstrive.mybatis_plus.model.AnnotationUser7Bean;
import org.junit.jupiter.api.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@RunWith(SpringRunner.class)
@SpringBootTest
class AnnotationDemo7 {
@Autowired
private AnnotationUser7Mapper userMapper;
@Test
void contextLoads() throws Exception {
// 删除用户ID为1的用户信息
AnnotationUser7Bean oldUserBean = userMapper.selectById(1);
if(null != oldUserBean) {
userMapper.deleteById(oldUserBean.getUserId());
}
// 查询用户信息
QueryWrapper<AnnotationUser7Bean> wrapper = new QueryWrapper<>();
wrapper.lt("user_id", 10);
for(AnnotationUser7Bean item : userMapper.selectList(wrapper)) {
System.out.println(item);
}
}
}
7.2 数据库代码执行说明
根据用户ID查询用户信息
Preparing: SELECT user_id,name,sex,age,deleted FROM user WHERE user_id=? AND deleted='0'
Parameters: 1(Integer)
根据用户ID删除用户信息
sql 是一个更新语句,这是因为我们使用了逻辑删除,而不是物理删除
Preparing: UPDATE user SET deleted='1' WHERE user_id=? AND deleted='0'
Parameters: 1(Integer)
查询用户ID小于10的用户信息
Preparing: SELECT user_id,name,sex,age,deleted FROM user WHERE deleted='0' AND (user_id < ?)
Parameters: 10(Integer)
欢迎加入我的知识星球,全面提升技术能力。
👉 加入方式,“长按”或“扫描”下方二维码噢:
星球的内容包括:项目实战、面试招聘、源码解析、学习路线。
文章有帮助的话,在看,转发吧。
谢谢支持哟 (*^__^*)