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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • git下载安装教程

    git下载安装教程git下载安装教程前言:因为最近突然对使用github搭建一个自己的网站并绑定域名特别着迷,但是前提条件是必须得安装git,于是便把安装过程记录下来,便利自己,帮助他人。1.访问git官网下载最新版本git官方网页:https://git-scm.com/download/win在git官网中,有不同操作系统下的git,选择符合自己电脑版本的进行下载就可以了这里我选择的windows,然后根据自己电脑是32位还是64位,在下面两个选项中选择选择好了静待其下好就好了或许会有下载缓慢或无法下

    2022年6月11日
    31
  • Oracle联合索引

    Oracle联合索引Oracle联合索引分类:Oracle2012-12-0809:352110人阅读评论(0)收藏举报我现在用的是oracle9i1.一个表建立多少个索引比较合适?比如说不大于5个这个没有定论,楼主要综合查询效率和dml效率自己确定,索引可以加快select的查询速度,但也会降低delete,insert和update等dml语句的执行速度。2.联…

    2022年5月26日
    121
  • 信用标准评分卡模型开发及实现方案_信用评分卡模型的建立

    信用标准评分卡模型开发及实现方案_信用评分卡模型的建立一、信用风险评级模型的类型信用风险计量体系包括主体评级模型和债项评级两部分。主体评级和债项评级均有一系列评级模型组成,其中主体评级模型可用“四张卡”来表示,分别是A卡、B卡、C卡和F卡;债项评级模型通常按照主体的融资用途,分为企业融资模型、现金流融资模型和项目融资模型等。A卡,又称为申请者评级模型,主要应用于相关融资类业务中新用户的主体评级,适用于个人和机构融资主体。B卡,又称为行为评级模型

    2025年8月21日
    3
  • JMeter之性能测试流程及性能测试关注点

    JMeter之性能测试流程及性能测试关注点

    2021年7月13日
    170
  • huffman编码——原理与实现

    huffman编码——原理与实现

    2021年12月6日
    39
  • java心得体会_初学java之心得体会

    java心得体会_初学java之心得体会0.前言从学习java以来,已经进行过三次pta作业的训练。虽然每次作业的完成都遇到了些许困难和障碍,不是一帆风顺的,但通过自己的摸索,实践,总能完成作业要求,每次作业之后都有不同的收获。这些新的收获告诉我,实践出真知,动手会学习到更多东西。总结前面的三次作业,我发现面向对象程序设计这种语言不再那么神秘,我相信马上就能看到揭开神秘面纱后的的它。1.作业过程总结(1).总结三次作业的知识迭代关系第一…

    2022年7月9日
    20

发表回复

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

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