前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >java逻辑删除_MybatisPlus中的删除和逻辑删除及区别介绍

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

作者头像
全栈程序员站长
发布于 2022-09-05 02:19:38
发布于 2022-09-05 02:19:38
1.8K0
举报

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

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

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

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

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

首先假设我有这样一张表

实体类:

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);

}

结果:

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

二、逻辑删除

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

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

/*

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

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

*/

@TableLogic

private Integer deleted;

(3)测试

/**

* 逻辑删除

*/

@Test

public void testLogicDelete() {

int count = userMapper.deleteById(5L);

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

}

结果:

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

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

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

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

@Test

public void testSelect() {

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

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

}

结果:

总结

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

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年6月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
走进JavaWeb技术世界4:Servlet 工作原理详解
本系列文章将整理到我在GitHub上的《Java面试指南》仓库,更多精彩内容请到我的仓库里查看
Java技术江湖
2019/10/21
5710
Java Web 33道面试题
HTTP 协议有 HTTP/1.0 版本和 HTTP/1.1 版本。HTTP1.1 默认保持长连接(HTTP persistent connection,也翻译为持久连接),数据传输完成了保持 TCP 连接不断开(不发 RST 包、不四次握手),等待在同域名下继续用这个通道传输数据;相反的就是短连接。
小熊学Java
2023/10/23
3080
Java Web 33道面试题
不知道这些Servlet规范、容器,还敢说自己是Java程序员?
实现Web动态内容的技术,最早使用的是CGI(Common Gateway Interface,通用网关接口)技术,根据用户输入的请求动态地传送HTML数据。 CGI并不是开发语言,而只是能够利用为它编写的程序来实现Web服务器的一种协议。 可用来实现电子商务网站、搜索引擎处理和在线登记等功能。当用户在Web页面中提交输入的数据时,Web浏览器就会将用户输入的数据发送到Web服务器上。在服务器上,CGI程序对输入的数据进行格式化,并将这个信息发送给数据库或服务器上运行的其他程序,然后将结果返回给Web服务器。最后,Web服务器将结果发送给Web浏览器,这些结果有时使用新的Web页面显示,有时在当前Web页面中显示。
JavaEdge
2021/12/07
5100
不知道这些Servlet规范、容器,还敢说自己是Java程序员?
Java Web基础面试题整理
a、API:有一个接口servlet,它是servlet规范中定义的用来处理客户端请求的程序需要实现的顶级接口。
Java团长
2018/09/27
2.1K1
Java Web基础面试题整理
servlet/tomcat等容器/springMVC之间的关系
Servlet是JavaEE规范的一种,主要是为了扩展Java作为Web服务的功能,统一接口。由其他内部厂商如tomcat,jetty内部实现web的功能。如一个http请求到来: 容器将请求封装为servlet中的HttpServletRequest对象,调用init(),service()等方法输出response,由容器包装为httpresponse返回给客户端的过程。
Monica2333
2020/06/19
1.2K0
不知道这些Servlet规范、容器,还敢说自己是Java程序员?
浏览器发给服务端的是一个HTTP格式的请求,HTTP服务器收到这个请求后,需要调用服务端程序来处理。
JavaEdge
2021/10/18
1.2K0
程序员的20大JSP面试问题及答案
1.JSP与Java Servlet一样,是在服务器端执行的,通常返回该客户端的就是一个HTML文本,因此客户端只要有浏览器就能浏览
鱼找水需要时间
2023/12/23
2970
web服务器有哪些?_服务器和web服务器有什么区别
如果一个软件的主要部分采用了”网络服务”,即它把存储或计算环节”外包”给其他网站了,那么我们就说这个软件属于Web Service架构。
全栈程序员站长
2022/11/04
9.2K0
web服务器有哪些?_服务器和web服务器有什么区别
猿进化系列9——一文学会java web开发基础
昨天猿人工厂君像你安利了web开发的一些套路,其中最大的套路就算是思考了,因为猿人的一生都是一个不停思考的过程,你也可以回头再看看,顺藤摸瓜,学到很多知识噢。在快速进化变身为猿人的过程中,学会使用特定的工具,去解决特定场景的问题,也是一个快速进化的不二法宝。
山旮旯的胖子
2020/07/28
3800
猿进化系列9——一文学会java web开发基础
整理+学习《骆昊-Java面试题全集(中)》
答:Servlet与CGI的区别在于Servlet处于服务器进程中,它通过多线程方式运行其service()方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于Servlet。
黑泽君
2018/12/27
9820
整理+学习《骆昊-Java面试题全集(中)》
Java Web开发API Boy如何进阶?
导语 | Java Web后台开发基本都离不开Spring生态这一套,Spring框架功能极其强大,会帮忙做许多工作,我们通常只需要在一个函数(包含request和response两个入参)中写处理逻辑即可。但是想要真正写好工业级的Java Web应用,对于开发细节必须有更深入的了解,比如一个Http请求发过来之后,解析请求的代码在哪里,是不是Spring框架做的解析?写的业务逻辑代码没有main函数入口,是如何被调用执行的?开发中用到的Listerner,Filter,Interceptor到底是什
腾讯云开发者
2021/06/25
5670
web服务器有哪几种_web服务器的虚拟目录
当我们打开电脑,通过浏览器看到的网站,所有网站服务器多是我们所说的web服务器,具体解释就是一种驻留在Internet上的计算机程序,web服务器通过存储网站文件,放置大小不一各类数据文件,来进行工作,所以世界上每个角落多有它的身影。 我们常见的Web服务器协议有三种,1、HTTP协议,2、HTML文档格式,最后是浏览器统一资源定位器,也就是我们常见的URL。 第一种:IIS IIS是我们网站用的最普遍的web服务器,IIS允许在公共网络上或者普通网络上发布信息的服务器,使IIS成为使用最广的web服务器之一。我们经常使用的网站很多都是建立在IIS的平台上进行运营,得到很多用户信赖。其中这里说道的IIS指的是一种web服务组件,里面还包括了FTP服务器、NNTP服务器等等服务器,分别进行网页浏览、文件传输等功能,由于IIS的帮助,很多不懂程序的网站管理也能轻松管理网站。
全栈程序员站长
2022/11/04
1.4K0
web容器和web服务器区别关系_java中间件有哪些
我们经常会被Web服务器、Web容器和Web中间件这三个概念搞混。因为我们常见的很多网站要么是由IIS搭建,要么是由Apache、Tomcat、Ngnix搭建。所以,我们会把他们都叫成是Web服务器,因为他们都提供了Web服务,可以让我们通过http协议访问到。但是又有很多地方会说Tomcat是Servlet容器,而又有很多地方会说Tomcat是Web中间件!那么,他们到底是Web服务器还是容器,还是Web中间件呢???
全栈程序员站长
2022/11/16
1.6K0
Web服务器、应用程序服务器、HTTP服务器区别
WEB服务器、应用程序服务器、HTTP服务器有何区别?IIS、Apache、Tomcat、Weblogic、WebSphere 都各属于哪种服务器?这些问题困惑了很久,今天终于梳理清楚了:
哲洛不闹
2018/09/14
9.7K0
servlet/filter/listener/interceptor区别与联系
1、servlet:servlet是一种运行服务器端的java应用程序,具有独立于平台和协议的特性,并且可以动态的生成web页面,它工作在客户端请求与服务器响应的中间层。最早支持 Servlet 技术的是 JavaSoft 的 Java Web Server。此后,一些其它的基于 Java 的 Web Server 开始支持标准的 Servlet API。Servlet 的主要功能在于交互式地浏览和修改数据,生成动态 Web 内容。这个过程为:
会说话的丶猫
2020/08/06
8840
servlet/filter/listener/interceptor区别与联系
编程体系结构(07):JavaEE之Web开发
客户端/服务器(Client/Server)模式,既要编写服务器端程序,也要开发客户端程序,软件更新时需要同时更新客户端和服务器端,整体模式相比BS架构要复杂,但是安全性比较高。
知了一笑
2020/10/19
6550
编程体系结构(07):JavaEE之Web开发
经典Java面试题收集(二)
答:Servlet与CGI的区别在于Servlet处于服务器进程中,它通过多线程方式运行其service()方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于Servlet。
gnnngu
2018/03/15
2K0
经典Java面试题收集(二)
JSP/Servlet Web 学习笔记 DayFive
  (1)在Web容器初始化Servlet实例时,都会为这个Servlet准备一个唯一的ServletConfig实例(俗称Servlet配置对象)。
Rekent
2018/09/04
4310
java过滤器和监听器的区别[拦截器监听器过滤器执行顺序]
大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说java过滤器和监听器的区别[拦截器监听器过滤器执行顺序],希望能够帮助大家进步!!!
Java架构师必看
2022/03/08
5830
JavaWeb(一)之细说Servlet
前言   其实javaWeb的知识早就学过了,可是因为现在在搞大数据开发,所以web的知识都忘记了。准备开始慢慢的把Web的知识一点一点的回忆起来,多学一点没有关系,就怕到时候要用的话,什么都不会了。 一、Servlet概述 1.1、Servlet简介   Servlet 运行在服务端的Java小程序,是sun公司提供一套规范(接口),用来处理客户端请求、响应给浏览器的动态资源。但servlet的实质就是java代码,通过java的API 动态的向客户端输出内容。   Servlet是Java Web的三大
用户1195962
2018/01/18
6510
JavaWeb(一)之细说Servlet
相关推荐
走进JavaWeb技术世界4:Servlet 工作原理详解
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档