MyBatis(35)如何在 MyBatis 中实现软删除

ops/2024/9/24 21:20:53/

实现软删除在MyBatis中通常意味着更新数据库记录的某个字段,而不是真正地从数据库中删除记录。这个字段(通常是is_deleteddeletedstatus等)被用来标记记录是否被删除。下面我们将详细探讨如何在MyBatis中实现软删除,包括数据库设计、MyBatis映射文件配置、以及如何通过MyBatis执行软删除操作。

数据库设计

首先,假设我们有一个users表,我们要为这个表添加一个is_deleted字段来表示记录是否被软删除。字段类型为TINYINT,其中0表示未删除,1表示已删除。

CREATE TABLE `users` (`id` INT AUTO_INCREMENT PRIMARY KEY,`username` VARCHAR(50) NOT NULL,`email` VARCHAR(50) NOT NULL,`is_deleted` TINYINT(1) NOT NULL DEFAULT 0
);

MyBatis Mapper文件配置

为了在MyBatis中使用软删除,我们需要在Mapper文件中定义相应的SQL操作。这包括更新is_deleted字段的操作来实现软删除,以及查询时过滤掉被软删除记录的操作。

UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="example.UserMapper"><!-- 软删除操作 --><update id="softDeleteUser" parameterType="int">UPDATE usersSET is_deleted = 1WHERE id = #{id}</update><!-- 查询所有未软删除的用户 --><select id="findAllActiveUsers" resultType="example.User">SELECT id, username, emailFROM usersWHERE is_deleted = 0</select></mapper>

使用MyBatis执行软删除

接下来,你需要在你的应用程序中调用Mapper接口中定义的方法来执行软删除。

public interface UserMapper {void softDeleteUser(int id);List<User> findAllActiveUsers();
}

执行软删除

在你的服务层或者控制器层,你可以调用softDeleteUser方法来软删除一个用户。例如:

public class UserService {private final UserMapper userMapper;public UserService(UserMapper userMapper) {this.userMapper = userMapper;}public void deleteUser(int userId) {userMapper.softDeleteUser(userId);}}

在这个示例中,调用deleteUser方法会更新指定用户的is_deleted字段为1,而不是从数据库中完全删除该记录。这是软删除的典型做法。

查询未被软删除的用户

当需要获取用户列表时,你可以调用findAllActiveUsers方法,它只会返回那些is_deleted字段为0(即未被软删除)的用户。

public class UserService {// 其他代码...public List<User> getUsers() {return userMapper.findAllActiveUsers();}}

总结

通过在数据库设计中添加一个is_deleted字段,以及在MyBatis Mapper文件中定义软删除和查询未删除记录的操作,我们可以在MyBatis中实现软删除功能。这种方法允许我们保留被“删除”的记录,同时还能够轻松地查询和恢复这些记录。软删除是一种常见且实用的技术,特别是在需要保留数据历史或者避免意外永久删除数据时。


http://www.ppmy.cn/ops/56761.html

相关文章

【GameFramework框架】7-2、GameFramework框架是否“过度设计”?

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址QQ群:398291828大家好,我是佛系工程师☆恬静的小魔龙☆,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 一、前言 【GameFramework框架】系列教程目录: https://blog.csdn.net/q764424567/article/details/1…

VSCode 远程反复输入密码不能链接问题解决

通过 vscode 远程连接服务器时出现了连接不上&#xff0c;而且一直要循环输入密码的问题&#xff0c;可能是因为上次异常退出导致。 主要解决思路是删除当前 vscode 远端服务后&#xff0c;重新建立连接。 解决方法一 在 vscode 端接口删除 vscode 服务。 View->Commond…

SQL注入安全漏洞与防御策略

1.引言 SQL注入&#xff08;SQL Injection&#xff09;是一种广泛存在的网络安全攻击手段&#xff0c;它允许攻击者通过向应用程序的数据库查询中插入或“注入”恶意的SQL代码片段&#xff0c;从而操控后端数据库&#xff0c;执行未授权的数据库操作&#xff0c;如数据泄露、数…

Python精神病算法和自我认知异类数学模型

&#x1f3af;要点 &#x1f3af;空间不确定性和动态相互作用自我认知异类模型 | &#x1f3af;精神病神经元算法推理 | &#x1f3af;集体信念催化个人行动力数学模型 | &#x1f3af;物种基因进化关系网络算法 | &#x1f3af;电路噪声低功耗容错解码算法 &#x1f4dc;和-…

Kafka接收消息

// 采用监听得方式接收 Payload标记消息体内容. KafkaListener(topics {"test"},groupId "hello") public void onEvent(Payload String event,Header(value KafkaHeaders.RECEIVED_TOPIC) String topic,Header(value KafkaHeaders.RECEIVED_PARTITION…

界面控件DevExpress JS ASP.NET Core v24.1 - 全新的分割器组件

DevExtreme拥有高性能的HTML5 / JavaScript小部件集合&#xff0c;使您可以利用现代Web开发堆栈&#xff08;包括React&#xff0c;Angular&#xff0c;ASP.NET Core&#xff0c;jQuery&#xff0c;Knockout等&#xff09;构建交互式的Web应用程序。从Angular和Reac&#xff0c…

【JAVA poi-tl-ext 富文本转word】

富文本转word 环境使用poi-tl-ext的原因富文本转word代码 环境 jdk 1.8 <dependency><groupId>io.github.draco1023</groupId><artifactId>poi-tl-ext</artifactId><version>0.4.16</version> </dependency>poi-tl-ext已经包…

亚信安全新一代终端安全TrustOne2024年重磅升级

以极简新主义为核心&#xff0c;亚信安全新一代终端安全TrustOne自2023年发布以来&#xff0c;带动了数字化终端安全的革新。60%&#xff0c;安装部署及管理效率的提升&#xff1b;50%&#xff0c;安全管理资源的节省&#xff1b;100%&#xff0c;信创非信创场景的全覆盖。Trus…