数据管理是软件开发中的基本组成部分,特别是在处理需要从活跃使用中删除的记录时。许多应用程序使用称为“软删除”的技术,而不是永久删除记录(称为“硬删除”的方法)。 “软删除”方法是一种广泛使用的解决方案,可将记录标记为非活动状态而不永久删除它们,从而轻松实现数据恢复和历史跟踪。
目前,与 Spring Data JPA 和 Hibernate 不同,Spring Data R2DBC 不提供用于自动处理软删除的内置注释。因此,开发人员求助于使用自定义存储库实现或查询来实现类似的功能。
在本文中,我们将研究软删除、其优点以及如何使用 R2DBC 在 Spring WebFlux 应用程序中实现它。
什么是软删除
软删除是一种数据管理方法,其中记录被标记为不活动或“已删除”,而不从数据库中删除。通常,这涉及向实体添加一个字段,例如deleted(布尔值)或deletedDate(时间戳),以指示记录不再活动。软删除不是永久删除数据,而是将记录标记为逻辑删除,将其隐藏在标准查询中,同时保留它以供潜在的恢复或审核。
软删除的好处
- 数据恢复:软删除可以轻松恢复数据。如果一条记录被意外删除,可以通过重置标志来快速“恢复删除”,确保数据不会永久丢失。
- 历史数据:软删除提供审计跟踪。组织通常需要保留历史数据以实现合规性或报告目的,而软删除可以在不拥挤活动数据的情况下实现这一点。
- 数据完整性:在关系复杂的系统中,永久删除记录可能会导致链接损坏和数据不一致。软删除通过保持相关数据完整,同时将删除的记录标记为非活动来解决这个问题。
- 安全性和合规性:法规通常要求将数据保留特定期限。软删除使开发人员能够满足这些合规性需求,而无需向普通用户提供数据。
如何使用 Spring Reactive 和 R2DBC 实现软删除
如果您有兴趣自己实现这一点,我准备了一个入门代码 - 一个带有基本 CRUD 端点和单元测试用例的简单博客应用程序。您可以使用此链接从我的 GitHub 存储库访问起始代码。那么,让我们开始吧。
步骤 1:添加字段以将记录标记为已删除
要实现此目的,请在实体类中添加一个字段来表示删除状态。更有效的方法是创建一个抽象类 (AbstractSoftDeletableEntity),在其中定义删除状态字段,并让实体类扩展此抽象类。该字段可以是指示记录是否被删除的布尔值(已删除),也可以是指示删除时间的时间戳(deletedDate)。我建议使用时间戳,因为它提供了删除发生时间的附加详细信息:
第二步:修改实体类,扩展抽象类
修改实体类以扩展 AbstractSoftDeletableEntity
创建一定程度的抽象和关注点分离,从而遵守面向对象设计的单一职责原则。步骤 3:创建扩展 SimpleR2dbcRepository 的通用自定义存储库 许多有关实现软删除的资源建议为每个实体使用自定义存储库,当应用程序具有大量实体时,这可能会很麻烦且难以管理。更好的方法是使用通用存储库接口,同时为基本方法提供自定义实现,例如 counts、deleteById、deleteAll、
findById在上面的代码片段中,我有 SoftDeleteRepositoryImpl
实现了步骤 4:修改实体存储库以扩展自定义存储库接口 最后,通过扩展 SoftDeleteRepository 并提供实体类名称和 id 数据类型作为泛型类型参数来修改主存储库接口。它还为 findById、findAll、deleteById 和
deleteAll接口中。
第 5 步:在服务层实施软删除
结论
软删除是一种有效且灵活的数据管理方法,无需永久删除数据,非常适合需要数据恢复、合规性或历史数据跟踪的应用程序。在本指南中,我们讨论了软删除是什么、它的优点以及如何使用 R2DBC 在 Spring WebFlux 应用程序中实现它。
您可以在 GitHub 上找到完整的源代码
以上是使用 RC 在 Spring WebFlux 中实现软删除的详细内容。更多信息请关注PHP中文网其他相关文章!

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

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

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

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

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

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

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


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

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