搜索
首页Javajava教程使用 RC 在 Spring WebFlux 中实现软删除

Implementing Soft Delete in Spring WebFlux with RC

数据管理是软件开发中的基本组成部分,特别是在处理需要从活跃使用中删除的记录时。许多应用程序使用称为“软删除”的技术,而不是永久删除记录(称为“硬删除”的方法)。 “软删除”方法是一种广泛使用的解决方案,可将记录标记为非活动状态而不永久删除它们,从而轻松实现数据恢复和历史跟踪。

目前,与 Spring Data JPA 和 Hibernate 不同,Spring Data R2DBC 不提供用于自动处理软删除的内置注释。因此,开发人员求助于使用自定义存储库实现或查询来实现类似的功能。

在本文中,我们将研究软删除、其优点以及如何使用 R2DBC 在 Spring WebFlux 应用程序中实现它。

什么是软删除

软删除是一种数据管理方法,其中记录被标记为不活动或“已删除”,而不从数据库中删除。通常,这涉及向实体添加一个字段,例如deleted(布尔值)或deletedDate(时间戳),以指示记录不再活动。软删除不是永久删除数据,而是将记录标记为逻辑删除,将其隐藏在标准查询中,同时保留它以供潜在的恢复或审核。

软删除的好处

  1. 数据恢复:软删除可以轻松恢复数据。如果一条记录被意外删除,可以通过重置标志来快速“恢复删除”,确保数据不会永久丢失。
  2. 历史数据:软删除提供审计跟踪。组织通常需要保留历史数据以实现合规性或报告目的,而软删除可以在不拥挤活动数据的情况下实现这一点。
  3. 数据完整性:在关系复杂的系统中,永久删除记录可能会导致链接损坏和数据不一致。软删除通过保持相关数据完整,同时将删除的记录标记为非活动来解决这个问题。
  4. 安全性和合规性:法规通常要求将数据保留特定期限。软删除使开发人员能够满足这些合规性需求,而无需向普通用户提供数据。

如何使用 Spring Reactive 和 R2DBC 实现软删除

如果您有兴趣自己实现这一点,我准备了一个入门代码 - 一个带有基本 CRUD 端点和单元测试用例的简单博客应用程序。您可以使用此链接从我的 GitHub 存储库访问起始代码。那么,让我们开始吧。

步骤 1:添加字段以将记录标记为已删除

要实现此目的,请在实体类中添加一个字段来表示删除状态。更有效的方法是创建一个抽象类 (AbstractSoftDeletableEntity),在其中定义删除状态字段,并让实体类扩展此抽象类。该字段可以是指示记录是否被删除的布尔值(已删除),也可以是指示删除时间的时间戳(deletedDate)。我建议使用时间戳,因为它提供了删除发生时间的附加详细信息:

第二步:修改实体类,扩展抽象类

修改实体类以扩展 AbstractSoftDeletableEntity

创建一定程度的抽象和关注点分离,从而遵守面向对象设计的单一职责原则。

步骤 3:创建扩展 SimpleR2dbcRepository 的通用自定义存储库 许多有关实现软删除的资源建议为每个实体使用自定义存储库,当应用程序具有大量实体时,这可能会很麻烦且难以管理。更好的方法是使用通用存储库接口,同时为基本方法提供自定义实现,例如 countsdeleteByIddeleteAll

findById
以及其他。

在上面的代码片段中,我有 SoftDeleteRepositoryImpl

实现了
SoftDeleteRepository
接口,它通过列出针对软删除操作增强的抽象方法来提供另一个抽象层。

步骤 4:修改实体存储库以扩展自定义存储库接口 最后,通过扩展 SoftDeleteRepository 并提供实体类名称和 id 数据类型作为泛型类型参数来修改主存储库接口。它还为 findByIdfindAlldeleteById

deleteAll
方法提供默认实现,以利用软删除自定义实现定义在
SoftDeleteRepository

接口中。

第 5 步:在服务层实施软删除
完成上述步骤后,一切就都准备好了。领域服务层不需要进一步的实现。值得注意的是,控制器和单元测试用例也不需要修改。<script></script> <script></script>要获取所有记录(包括已删除的记录)或已删除的记录,您可以使用如下代码片段所示的查询方法:<script></script> <script></script> <script></script> <script></script>

结论

软删除是一种有效且灵活的数据管理方法,无需永久删除数据,非常适合需要数据恢复、合规性或历史数据跟踪的应用程序。在本指南中,我们讨论了软删除是什么、它的优点以及如何使用 R2DBC 在 Spring WebFlux 应用程序中实现它。

您可以在 GitHub 上找到完整的源代码

以上是使用 RC 在 Spring WebFlux 中实现软删除的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何处理在IDEA中连接Oracle数据库时出现的数字溢出错误?如何处理在IDEA中连接Oracle数据库时出现的数字溢出错误?Apr 19, 2025 pm 04:15 PM

在IDEA中连接Oracle数据库时出现数字溢出错误的处理方法当我们在使用IntelliJ...

@ResultType注解在MyBatis中如何正确使用?@ResultType注解在MyBatis中如何正确使用?Apr 19, 2025 pm 04:12 PM

在研究MyBatis框架时,开发者们常常会遇到关于注解的各种问题,其中一个常见的问题是如何正确使用@ResultType注...

如何利用自然语言处理技术高效查询人员数据?如何利用自然语言处理技术高效查询人员数据?Apr 19, 2025 pm 04:09 PM

利用自然语言处理技术查询人员数据的方法在现代企业中,人员数据的管理和查询是一个常见的需求。假设我们...

SpringBoot多数据源配置下,数据库访问白天慢夜间快是什么原因?SpringBoot多数据源配置下,数据库访问白天慢夜间快是什么原因?Apr 19, 2025 pm 04:06 PM

Springboot项目多数据源配置下的数据库访问性能问题排查本文针对一个Springboot项目中使用Atomikos进行多数据源配�...

Java项目打包成JAR后出现NoClassDefFoundError: 如何排查JDK版本兼容性问题?Java项目打包成JAR后出现NoClassDefFoundError: 如何排查JDK版本兼容性问题?Apr 19, 2025 pm 04:03 PM

Java项目打包成可执行JAR文件时遭遇NoClassDefFoundError难题很多Java开发者在将项目打包成可执行JAR文件时,可能会�...

如何分析IntelliJ IDEA的破解过程并找到负责注册的lib或class?如何分析IntelliJ IDEA的破解过程并找到负责注册的lib或class?Apr 19, 2025 pm 04:00 PM

关于IntelliJIDEA破解的分析方法在编程界,IntelliJ...

如何使用Java和JavaCV提升视频质量?为什么效果有限?如何使用Java和JavaCV提升视频质量?为什么效果有限?Apr 19, 2025 pm 03:57 PM

问题介绍:视频质量提升是视频处理中的一个重要环节,尤其是在处理低清晰度的视频时,如何利用Java语言和�...

如何让SpringBoot中的@RequestBody注解正确接收非JSON格式的字符串参数?如何让SpringBoot中的@RequestBody注解正确接收非JSON格式的字符串参数?Apr 19, 2025 pm 03:54 PM

在处理SpringBoot应用中,我们经常会遇到如何正确接收请求参数的问题。特别是当参数格式不是常见的JSON时,更�...

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中