MyBatis-Plus中的逻辑删除使用详解
前言
开发系统时,有时候在实现功能时,删除操作需要实现逻辑删除就是将数据标记为删除,而并非真的物理删除(非DELETE操作),查询时需要携带状态条件,确保被标记的数据不被查询到。这样做的目的就是避免数据被真正的删除。
MP就提供了这样的功能,方便我们使用,接下来我们一起学习下~
一、修改表结构
为user表增加deleted字段,用于表示数据是否被删除,1代表删除,0代表未删除。sql代码如下
USE study; ALTER TABLE user ADD COLUMN deleted int(1) NULL DEFAULT 0 COMMENT '1代表删除,0代表未删除' AFTER user_status;
添加后的效果图展示:
二、User实体中添加属性
增加deleted属性并且添加@TableLogic注解
//标记字段 @TableLogic private Integer deleted;
三、配置
在application.properties下配置删除字段的标记,默认就是删除为1,未删除就为0。这个具体值大家可以修改,按开发要求即可。要是就是用默认值的话其实不配置下面的代码也可以执行的。
#删除标记为1 mybatis-plus.global-config.db-config.logic-delete-value=1 #未删除标记为0 mybatis-plus.global-config.db-config.logic-not-delete-value=0
四、测试
编写测试类,在测试类下编写testDeleteById方法,删除id为12的用户信息。删除成功后查询表中的数据查看是否能查询到id为12的结果。
/** * 删除操作 * */ //根据id删除 //int deleteById(Serializable id); @Test public void testDeleteById() { int result = this.userMapper.deleteById(12); if(result>0){ testSelectList(); System.out.println("删除成功!"); }else { System.out.println("删除失败!"); } }
效果图:
1. 查看日志会发现,第一个删除生成的sql代码其实是修改,只是将deleted字段等于0的条件下设置了deleted字段标记为1。
2. 查看日志,第二个查询的结果自动生成的sql代码中也自动添加了条件为deleted字段等于0。如下如图所示。
3. 通过查询输出的结果可发现查不到id为12的数据。如下图所示:
4. 我们从数据库中查看数据表的信息,会发现id为12的数据deleted字段已经被标记为1。所以不会查询到,但本身的数据没有真正的被删除(还存在数据库中)。
总结
在实际的开发中也是这样的,当用户点完删除数据信息后以为删除掉了,但实际上没你们想的那么简单。你的数据在数据库中不会轻易的删除掉的。只是不会显示在用户页面而已。大多数的开发其实都是这样,所以说该知识点也是很重要的。MP简化了我们的开发,的确可以体会到~
这就是逻辑删除的用法。做一个项目练练手就会了,相对而言比较好掌握。大家加油学起来~
到此这篇关于MyBatis-Plus中的逻辑删除使用的文章就介绍到这了,更多相关MyBatis-Plus逻辑删除使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Springboot 整合RabbitMq(用心看完这一篇就够了)
这篇文章主要介绍了Springboot 整合RabbitMq(用心看完这一篇就够了),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-12-12java long转String +Codeforces110A案例
这篇文章主要介绍了java long转String +Codeforces110A案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-09-09SpringBoot中的RestTemplate使用方法详解
这篇文章主要介绍了SpringBoot中的RestTemplate使用方法详解,为了方便使用,这里我封装成一个工具类来静态调用RestTemplate,基于SpringBoot2.4.2版本,需要的朋友可以参考下2024-01-01Java 语言守护线程 Daemon Thread使用示例详解
这篇文章主要为大家介绍了Java 语言守护线程 Daemon Thread使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-10-10
最新评论