java逻辑删除_MybatisPlus中的删除和逻辑删除及区别介绍

java逻辑删除_MybatisPlus中的删除和逻辑删除及区别介绍删除又分为逻辑删除和物理删除,那么它们有什么区别呢?物理删除:真实删除,将对应数据从数据库中删除,之后查询不到此条被删除数据。逻辑删除:假删除,将对应数据中代表是否被删除字段状态修改为“被删除状态”,之后在数据库中仍旧能看到此条数据记录。在我们日常开发中,为了保留数据,经常会使用逻辑删除的方式进行数据删除,下面我们就来看看物理删除与逻辑删除怎么实现的吧首先假设我有这样一张表实体类:package…

大家好,又见面了,我是你们的朋友全栈君。

删除又分为逻辑删除和物理删除,那么它们有什么区别呢?

物理删除:真实删除,将对应数据从数据库中删除,之后查询不到此条被删除数据。

逻辑删除:假删除,将对应数据中代表是否被删除字段状态修改为“被删除状态”,之后在数据库中仍旧能看到此条数据记录。

在我们日常开发中,为了保留数据,经常会使用逻辑删除的方式进行数据删除,下面我们就来看看物理删除与逻辑删除怎么实现的吧

首先假设我有这样一张表

57140854381446c58e021dbe2982c18f.png

实体类:

package com.atguigu.mybatis_plus.entity;

import java.util.Date;

import com.baomidou.mybatisplus.annotation.FieldFill;

import com.baomidou.mybatisplus.annotation.IdType;

import com.baomidou.mybatisplus.annotation.TableField;

import com.baomidou.mybatisplus.annotation.TableId;

import com.baomidou.mybatisplus.annotation.TableLogic;

import lombok.Data;

@Data

public class User {

@TableId(type = IdType.AUTO)

private Long id;

private String name;

private Integer age;

private String email;

@TableField(fill = FieldFill.INSERT)

private Date createTime;

// @TableField(fill = FieldFill.UPDATE)

@TableField(fill = FieldFill.INSERT_UPDATE)

private Date updateTime;

}

userMapper接口:

package com.atguigu.mybatis_plus.mapper;

import com.atguigu.mybatis_plus.entity.User;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;

// 继承BaseMapper后UserMapper就具有了CRUD功能

public interface UserMapper extends BaseMapper{

}

一、物理删除

1、根据id删除记录

@Test

public void testLogicDelete() {

int count = userMapper.deleteById(1L); // 删除id为1的数据

System.out.println(“受影响的行数”+count);

}

2、批量删除

@Test

public void testDeleteBatchIds() {

int result = userMapper.deleteBatchIds(Arrays.asList(2, 3, 4)); // 删除id为2,3,4的数据

System.out.println(result);

}

结果:

6fcf11dfcb84a8d77204083d7d2f525a.png

物理删除比较简单,接下来我们看看逻辑删除怎么实现吧!

二、逻辑删除

(1)数据库修改,添加 deleted字段

f57a5e68c4738e7cd3b4e5d03e920481.png

(2)实体类修改,添加deleted 字段,并加上 @TableLogic 注解

/*

加@TableLogic的情况下,程序内部会将delete语句变为update语句

实际上我们写的代码并不需要做出什么改变

*/

@TableLogic

private Integer deleted;

(3)测试

/**

* 逻辑删除

*/

@Test

public void testLogicDelete() {

int count = userMapper.deleteById(5L);

System.out.println(“受影响的行数”+count);

}

结果:

1b9c6b9d53e2709eb65662739dc390f2.png

2033d224c24c0d18f205de30742af650.png

测试后发现,数据并没有被删除,deleted字段的值由0变成了1

测试后分析打印的sql语句,是一条update

注意:被删除前,数据的deleted 字段的值必须是 0,才能被选取出来执行逻辑删除的操作

(5)测试逻辑删除后的查询,MyBatis Plus中查询操作也会自动添加逻辑删除字段的判断

@Test

public void testSelect() {

List users = userMapper.selectList(null); // 查询所有记录

users.forEach(System.out::println); // 遍历输出

}

结果:

b270db49b1c18b5416224d051d46410c.png

总结

到此这篇关于MybatisPlus中的删除和逻辑删除及区别介绍的文章就介绍到这了,更多相关MybatisPlus删除和逻辑删除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137253.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月2日 上午11:16
下一篇 2022年6月2日 上午11:16


相关推荐

  • 分布式爬虫架构_分布式爬虫工具有哪些

    分布式爬虫架构_分布式爬虫工具有哪些目录分布式爬虫框架消息队列Redis和Scrapy-Redis分布式爬虫框架分布式爬虫框架分为两种:控制模式(左)和自由模式(右):控制模式中的控制节点是系统实现中的瓶颈,自由模式则面临爬行节点之间的通信处理问题。因此,在实际工程中,我们通常使用混合模式:各个爬行节点有各自的功能(爬取的对象不同),它们都注册到一个服务节点上,服务节点能分辨各个爬行节点的分工,用户的请求存放在队列中,处理不同请求的程序从队列中取出请求,然后询问服务节点,由服务节点分配爬行节点给请求的处理程序。下面介绍分布式爬

    2025年7月4日
    3
  • 大规模储能技术_新技术储备

    大规模储能技术_新技术储备eBPF-Linux性能优化的超能力

    2025年11月30日
    8
  • sql索引语法

    sql索引语法一 索引 索引是一种快速访问数据的途径 可提高数据库性能 索引使数据库程序无须对整个表进行扫描 就可以在其中找到所需的数据 就像书的目录 可以快速查找所需的信息 无须阅读整本书 nbsp 一 索引的分类逻辑分类 单列索引 组合索引 唯一索引 非唯一索引 函数索引 物理分类 区分索引 非分区索引 B 树索引 正向索引 反向索引 位图索引 nbsp nbsp 二 索引的缺点 nbsp nbsp nbsp nbsp 1

    2026年3月26日
    1
  • 主成分分析(PCA)原理详解「建议收藏」

    “微信公众号”本文同步更新在我的微信公众号里,地址:https://mp.weixin.qq.com/s/Xt1vLQfB20rTmtLjiLsmww本文同步更新在我的知乎专栏里面:主成分分析(PCA)原理详解-Microstrong的文章-知乎https://zhuanlan.zhihu.com/p/377770741.相关背景在许多领域的研究与应用中,通常需要对含有多个变量的数据进行观…

    2022年4月16日
    36
  • soapUI工具使用方法、简介、接口测试[通俗易懂]

    soapUI工具使用方法、简介、接口测试[通俗易懂]一、soapUI简介SOAP:   WebService通过Http协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明HTTP消息头的内容格式,这些特定的HTTP消息头和XML内容格式就是SOAP协议。SOAP提供了标准的RPC方法来调用WebService。 SOAP协议 =HTTP协议 +XML数

    2022年6月17日
    49
  • python学习 day3

    python学习 day3

    2022年4月2日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号