MybatisPlus逻辑删除

MybatisPlus逻辑删除**MybatisPlus逻辑删除的使用**首先我们要知道为什么要进行逻辑删除:逻辑删除可以理解为假删除,并不是真的将数据进行删除。假删除只是为了数据安全起见,在数据库中增添一个字段,我们可以默认这个字段为1时数据被删除,而字段值为0时数据被删除想象一下这样的业务场景,当一位公司职员离职,但是手续还没有办理,这时我们便可以设置逻辑删除,以保证其信息不会被立刻删除。我们电脑里的回收站正是利用了逻辑删除,我们点击删除的文件不会被立刻删除,而是放入回收站,等我们反悔时可以将其进行还原。在Mybat

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

**

MybatisPlus——逻辑删除

**
首先我们要知道为什么要进行逻辑删除
逻辑删除可以理解为假删除,并不是真的将数据进行删除。

假删除只是为了数据安全起见,在数据库中增添一个字段,我们可以默认这个字段为1时数据被删除,而字段值为0时数据被删除

逻辑删除是为了方便数据恢复和保护数据本身价值的一种方案。我们电脑里的回收站正是利用了逻辑删除,我们点击删除的文件不会被立刻删除,而是放入回收站,等我们反悔时可以将其进行还原。

在MybatisPlus中设置逻辑删除有以下几个步骤

1.首先为Strudent表添加logic_delete字段,通过判断logic_delete字段的数值,我们可以确定数据是否已被删除
在这里插入图片描述

2.如果logic_delete字段在数据库中并没有设置默认值(推荐设置默认值,这样更加方便),我们需要在applicationContext.xml文件中对默认值进行设置,已设置默认值可跳过此步


    <bean id="sqlSessionFactoryBean" class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean">
<!--配置globalConfig,在全局中对默认值进行设置-->
        <property name="globalConfig" ref="globalConfig"></property>

        <property name="dataSource" ref="dataSource"></property>

        <property name="configLocation" value="classpath:mybatis.xml"></property>

        <property name="typeAliasesPackage" value="com.yq.entity"></property>
    </bean>
    <bean id="globalConfig" class="com.baomidou.mybatisplus.core.config.GlobalConfig">
        <property name="dbConfig">
            <bean class="com.baomidou.mybatisplus.core.config.GlobalConfig.DbConfig">
            <!-默认被删除为1-->
                <property name="logicDeleteValue" value="1"></property>
            <!-默认未被删除为0-->
                <property name="logicNotDeleteValue" value="0"></property>
            </bean>
        </property>
    </bean>

3.实体类属性与表中字段保持一致,属性 logicDelete添加@TableLogic注解

package com.yq.entity;

import com.baomidou.mybatisplus.annotation.*;
import com.baomidou.mybatisplus.extension.activerecord.Model;


public class Student extends Model<Student> { 
   
    @TableId(type = IdType.AUTO)
    private int stuNo;
    private String stuName;
    @Version
    private Integer version;
    private int stuAge;

    //逻辑删除字段
    @TableLogic
    private Integer logicDelete;//这里用Integer默认为null,而int默认为0,0会产生误解


    public Student(int stuNo, String stuName, Integer version, int stuAge) { 
   
        this.stuNo = stuNo;
        this.stuName = stuName;
        this.version = version;
        this.stuAge = stuAge;
    }

    public Student(int stuNo, String stuName, int stuAge) { 
   
        this.stuNo = stuNo;
        this.stuName = stuName;
        this.stuAge = stuAge;
    }

    public Student(String stuName, int stuAge) { 
   
        this.stuName = stuName;
        this.stuAge = stuAge;
    }

    public Student() { 
   
    }

    public int getStuNo() { 
   
        return stuNo;
    }

    public void setStuNo(int stuNo) { 
   
        this.stuNo = stuNo;
    }

    public String getStuName() { 
   
        return stuName;
    }

    public void setStuName(String stuName) { 
   
        this.stuName = stuName;
    }

    public int getStuAge() { 
   
        return stuAge;
    }

    public void setStuAge(int stuAge) { 
   
        this.stuAge = stuAge;
    }



    public Integer getVersion() { 
   
        return version;
    }

    public void setVersion(Integer version) { 
   
        this.version = version;
    }

    public Integer getLogicDelete() { 
   
        return logicDelete;
    }

    public void setLogicDelete(Integer logicDelete) { 
   
        this.logicDelete = logicDelete;
    }
}

4.进行简单调用,查看结果

    //测试假删
    public static void testLogicdelete(){ 
   
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
        StudentMapper studentMapper = context.getBean("studentMapper", StudentMapper.class);
        studentMapper.delete(null);
    }

    public static void main(String[] args) throws Exception { 
   
                    testLogicdelete();
    }

执行方法之前的数据库表:
在这里插入图片描述
执行方法之后的数据库表:
在这里插入图片描述

此时我们查看日志发现
我们原本执行的删除语句(delete from student ):
在这里插入图片描述
在日志中变为对logic_delete字段的更新操作:
在这里插入图片描述

执行删除语句后数据并没有被直接删除,而且MybatisPlus自动将logic_delete字段的值更新为1,使其处于假删状态,保证了数据安全。

当我们数据库中所有数据的字段logic_delete为1,也就是被删除时,我们进行查询全部操作,发现
select * from student语句被转换为
SELECT stu_no,stu_name,version,stu_age,logic_delete FROM student WHERE logic_delete=0

在这里插入图片描述

MybatisPlus为我们自动进行了拼接操作将 WHERE logic_delete=0 在查询语句后进行拼接,以保证我们只能查询出
logic_delete=0 ,也就是未被删除的数据

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ES6 数组新增方法

    ES6 数组新增方法目录ES6数组新增方法1、.map2、some和every方法3、filter4、数组新增的reduce方法ES6数组新增方法1、.map.map()给数组中的每一个元素添加特殊处理,返回新的数组实现给定数组添加元letprices=[20,30,40]//20元30元40元letarr=prices.map(item=>item+”元”)给给定数据替换某内容letmovies=[{id:1,name:’逃学…

    2022年5月10日
    39
  • 博弈论集锦

    博弈论集锦看完这么多效应及定理,能否总结成一条?1.马太效应   《新约马太福音》中有这样一个故事,一个国王远行前,交给三个仆人每人一锭银子,吩咐他们:“你们去做生意,等我回来时,再来见我。”国王回来时,第一个仆人说:“主人,你交给我们的一锭银子,我已赚了10锭。”于是国王奖励他10座城邑。第二个仆人报告说:“主人,你给我的一锭银子,我已赚了5锭。”于是国王例奖励了他5座城邑。第三个

    2022年5月4日
    37
  • robots书写说明:

    robots书写说明:

    2021年10月9日
    58
  • 查看Linux内核版本的命令_ubuntu 查看内核

    查看Linux内核版本的命令_ubuntu 查看内核有朋友在使用Linux的过程中要查看Linux的内核版本号,这要怎么看呢?也有朋友文要怎么查看linux系统版本信息呢?下面和小编一起了解一下吧。一、查看linux内核版本号1:登录linux,在终端输入cat/proc/version2:登录linux,在终端输入uname-a即列出linux的内核版本号。二、查看linux系统版本信息1:登录到linux服务器执行lsb_rele…

    2022年8月23日
    7
  • 关于pycharm安装第三方库的一些方法_pycharm安装本地第三方库

    关于pycharm安装第三方库的一些方法_pycharm安装本地第三方库问题集合记得关梯子记得关梯子记得关梯子要是遇到pip命令报错,或者在pycharm中无法下载第三方库,首先检查一下梯子是否开了的。我的环境:pycharm+anaconda虚拟环境问题1:问题:WARNING:Youareusingpipversion21.2.4;however,version21.3.1isavailable.Youshouldconsiderupgradingviathe’D:\anaconda\envs\py36\python.e

    2022年8月28日
    2
  • SPI接口介绍

    SPI接口介绍SPI接口的全称是”SerialPeripheralInterface”,即串行外围接口。SPI接口主要应用在EEPROM、FLASH、实时时钟、AD转换器,还有数字信号处理器和数字信号解码器之间。SPI接口是在CPU和外围低速器件之间进行同步串行数据传输,在主器件的移位脉冲下,数据按位传输,高位在前,低位在后,为全双工通信,数据传输速度总体来说比I2C总线要快,速度可达到几十Mbps。S

    2022年6月18日
    44

发表回复

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

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