MyBatis-Plus实现逻辑删除[MyBatis-Plus系列] - 492篇

2023-10-24 04:04

本文主要是介绍MyBatis-Plus实现逻辑删除[MyBatis-Plus系列] - 492篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

历史文章(文章累计490+)

《国内最全的Spring Boot系列之一》

《国内最全的Spring Boot系列之二》

《国内最全的Spring Boot系列之三》

《国内最全的Spring Boot系列之四》

《国内最全的Spring Boot系列之五》

《国内最全的Spring Boot系列之六》

MyBatis-Plus通用Service快速实现赠三改查[MyBatis-Plus系列] - 第489篇

SpringBoot集成MyBatis-Plus + MyBatis-Plus代码生成器[MP系列] - 第490篇

MyBatis-Plus主键生成策略[MyBatis-Plus系列] - 第491篇

悟纤:师傅,你说有些时候,莫名其妙就会emo了,你说这是怎么一回事?

师傅:那是心里有什么事情想不明白了。

悟纤:那为什么问TA有什么事情没有?TA说没有。

师傅:有些时候,有些场景,有些话,在这个时候不适合说而已。

师傅:没有无缘无故emo的,也没有无缘无故的happy,所有的一切一切都是心里藏着事情,此时此刻无法想明白。

悟纤:那师傅要是自己好长时间想不明白,持续emo怎么办?

师傅:首先,需要认识自己的情绪。emo情绪包括忧愁、孤独、不安、沮丧等,当你感到这些情绪时,应该及时意识到并分析原因。可能是因为生活中的问题、工作上的压力、人际关系等问题导致的。了解自己的情绪,对于调整自己的心态非常重要。

师傅:寻找支持和安慰,当你感到心情低落时,不要独自承受,可以寻找支持和安慰。可以找家人、朋友或者专业心理咨询师聊天,倾诉自己的心声,分享自己的情绪。他们可以帮助你排解负面情绪,找到解决问题的方法。

师傅:寻找适合自己的发泄方式,当你感到愤怒、失落时,可以寻找适合自己的发泄方式。可以去健身房、跑步、听音乐、画画等方式释放负面情绪。找到适合自己的发泄方式,可以缓解自己的压力和情绪。

师傅:所有的事情都是心里过不了自己心里这一关。很多时候,让人感到痛苦的,并不是事情本身,而是你对这个事情的执念

悟纤:师傅,我要努力让自己开开心心的~,心情不好也不学会自己排解自己的情绪。

师傅:徒儿,加油~学习专业能力的同时,也需要提高自己的综合素质能力。

悟纤:徒儿明白了,我要开开心心的过好每天,强大自己~

导读

Hi,大家好,我是悟纤。过着爱谁谁的生活,活出不设限的人生。

在实际的项目中,在删除数据的时候,我们并不想真正的把数据删除掉,而是修改一个状态中,不查询出来而已,这个就是逻辑删除。

在MP中要实现逻辑删除,非常easy,只需要简单的配置即可。接下来就带大家实践一下。

一、逻辑删除和物理删除

物理删除:指文件存储所用到的磁存储区域被真正的擦除或清零,这样删除的文件是不可以恢复的,物理删除是计算机处理数据时的一个概念。如果在数据库中直接使用delete、drop删除了表数据,如果没有备份的话,数据就很难恢复了。

逻辑删除(软删除):逻辑删除就是对要被删除的数据打上一个删除标记,通常使用一个deleted字段标示行记录是不是被删除,比如该数据有一个字段deleted,当其值为0表示未删除,值为1表示删除。那么逻辑删除就是将0变成1。在逻辑上是数据是被删除的,但数据本身是依然存在的。

两者的优劣:

物理删除一定程度上删除了“无用”的数据,降低了表的数据量,对性能肯定是有好处的;但是如果没有备份的话,数据很难恢复。也无法对历史数据进行数据分析。

逻辑删除恢复的话只要修改deleted等类似的状态标示字段就可以了,但是表的数据量肯定会比物理删除增加了,并且查询时经常要考虑到deleted字段,对索引都会有影响。

所以一张表的数据是否采用逻辑删除,还要根据数据的重要性数据量查询性能以及业务需求等因素综合判断。

二、逻辑删除实现

接下来看下使用MP逻辑删除的实现。

2.1 表添加字段

首先为需要逻辑删除的表增加一个deleted字段作为逻辑删除字段,并且设置其默认值为0,如下:

CREATE TABLE photo  (    `id` bigint(0) NOT NULL AUTO_INCREMENT COMMENT '主键.',    `name` varchar(255) NULL COMMENT '名称',    `path` varchar(255) NULL COMMENT '地址',    `deleted` bit NULL DEFAULT 0 COMMENT '是否删除,0:未删除;1:删除',    PRIMARY KEY (`id`));

2.2字段上加上@TableLogic注解

给数据库表对应的实体类字段上加上@TableLogic注解:

/** * author:悟纤「公众号SpringBoot」 * date:2023/9/8 */@Datapublic class Photo {    @TableId(type = IdType.AUTO)    private Long id;//主键.    private String name;//名称    private String path;//地址.    @TableLogic //全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置)    private Boolean deleted;//是否删除,0:未删除;1:删除}

2.3 全局配置

全局配置该字段的各个状态的值:

#全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置@TableLogic)mybatis-plus.global-config.db-config.logic-delete-field=deleted#逻辑已删除值(默认为 1)mybatis-plus.global-config.db-config.logic-delete-value=1#逻辑未删除值(默认为 0)mybatis-plus.global-config.db-config.logic-not-delete-value=0

当然这个全局不配置的话,也可以通过注解@TableLogic进行配置:

@TableLogic(value = "0",delval = "1") private Boolean deleted;//是否删除,0:未删除;1:删除

但这个不好的地方,就是每个实体类都要进行配置,所以还是建议全局配置的方式。

2.4 定义Mapper

定义Photo的Mapper,这个就是正常编写即可:

public interface PhotoMapper extends BaseMapper<Photo> {}

2.5 测试

插入数据:

@Testpublic void testSave(){    Photo photo = new Photo();    photo.setName("初中的照片");    photo.setPath("/img/1.png");    photoMapper.insert(photo);}

说明:在插入数据的时候,这里并没有指定字段deleted,因为在建表的时候设置了默认值,所以默认值为0。

删除数据:

@Testpublic void testDelete(){    Photo photo = new Photo();    photo.setId(1L);    photoMapper.deleteById(photo);}

说明:这里执行MP的deleteById,但实际执行的SQL是update语句,修改了字段deleted的状态。

二次执行删除:

说明:当二次执行删除的时候,就修改失败了,因为这里在修改的时候,有一个条件deleted=0。

修改操作:

@Testpublic void testUpdate(){    Photo photo = new Photo();    photo.setId(1L);    photo.setName("高中的照片");    photoMapper.updateById(photo);}

说明:由于数据逻辑删除了,所以修改数据失败。

查询操作:

@Testpublic void testSelect(){    Photo photo = photoMapper.selectById(1);    System.out.println(photo);}

说明:由于数据逻辑删除了,所以无法查询到数据。

三、逻辑删除其它说明

对于数据的增删改查:

(1)插入: 不作限制。

(2)查找: 追加 where 条件过滤掉已删除数据,如果使用 wrapper.entity 生成的 where 条件也会自动追加该字段。

(3)更新: 追加 where 条件防止更新到已删除数据,如果使用 wrapper.entity 生成的 where 条件也会自动追加该字段。

(4)删除: 转变为 更新

字段类型支持说明:

(1)支持所有数据类型(推荐使用 Integer,Boolean,LocalDateTime)

(2)如果数据库字段使用datetime,逻辑未删除值和已删除值支持配置为字符串null,另一个值支持配置为函数来获取值如now()

其它说明:

(1)逻辑删除是为了方便数据恢复和保护数据本身价值等等的一种方案,但实际就是删除。

(2)如果你需要频繁查出来看就不应使用逻辑删除,而是以一个状态去表示。

小结

本小节带大家使用MP实现了逻辑删除,最后对于本文的重点做个小结:

(1)在MP中实现逻辑删除有两种方式:其一就是使用注解@TableLogic;其二就是在配置文件中全局配置(实际项目中推荐这种方式)。

(2)字段类型:支持所有数据类型(推荐使用 Integer,Boolean,LocalDateTime)

 点赞、转发、评论,伸出你的双手666…

 你就是你,不一样的小蚂蚁!

我就是我,是颜色不一样的烟火。
我就是我,是与众不同的小苹果。

à悟纤学院:https://t.cn/Rg3fKJD

学院中有Spring Boot相关的课程!点击「阅读原文」进行查看!

SpringBoot视频:http://t.cn/A6ZagYTi

SpringBoot交流平台:https://t.cn/R3QDhU0

SpringSecurity5.0视频:http://t.cn/A6ZadMBe

ShardingJDBC分库分表:http://t.cn/A6ZarrqS

分布式事务解决方案:http://t.cn/A6ZaBnIr

JVM内存模型调优实战:http://t.cn/A6wWMVqG

Spring入门到精通:https://t.cn/A6bFcDh4

大话设计模式之爱你:https://dwz.cn/wqO0MAy7

这篇关于MyBatis-Plus实现逻辑删除[MyBatis-Plus系列] - 492篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/272566

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景