◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
数据管理是软件开发中的基本组成部分,尤其是在处理需要从活跃使用中删除的记录时。许多应用程序使用称为“软删除”的技术,而不是永久删除记录(称为“硬删除”的方法)。 “软删除”方法是一种广泛使用的解决方案,可将记录标记为非活动状态而不永久删除它们,从而轻松实现数据恢复和历史跟踪。
目前,与 Spring Data JPA 和 Hibernate 不同,Spring Data R2DBC 不提供用于自动处理软删除的内置注释。因此,开发人员求助于使用自定义存储库实现或查询来实现类似的功能。
在本文中,我们将研究软删除、其优点以及如何使用 R2DBC 在 Spring WebFlux 应用程序中实现它。
软删除是一种数据管理方法,其中记录被标记为不活动或“已删除”,而不从数据库中删除。通常,这涉及向实体添加一个字段,例如deleted(布尔值)或deletedDate(时间戳),以指示记录不再活动。软删除不是永久删除数据,而是将记录标记为逻辑删除,将其隐藏在标准查询中,同时保留它以供潜在的恢复或审核。
如果您有兴趣自己实现这一点,我准备了一个入门代码 - 一个带有基本 CRUD 端点和单元测试用例的简单博客应用程序。您可以使用此链接从我的 GitHub 存储库访问起始代码。那么,让我们开始吧。
要实现此目的,请在实体类中添加一个字段来表示删除状态。更有效的方法是创建一个抽象类 (AbstractSoftDeletableEntity),在其中定义删除状态字段,并让实体类扩展此抽象类。该字段可以是指示记录是否被删除的布尔值(已删除),也可以是指示删除时间的时间戳(deletedDate)。我建议使用时间戳,因为它提供了删除发生时间的附加详细信息:
修改实体类以扩展 AbstractSoftDeletableEntity 创建一定程度的抽象和关注点分离,从而遵守面向对象设计的单一职责原则。
许多有关实现软删除的资源建议为每个实体使用自定义存储库,当应用程序具有大量实体时,这可能会很麻烦且难以管理。更好的方法是使用通用存储库接口,同时为基本方法提供自定义实现,例如 counts、deleteById、deleteAll、findById 和其他。
在上面的代码片段中,我有 SoftDeleteRepositoryImpl 实现了 SoftDeleteRepository 接口,它通过列出针对软删除操作增强的抽象方法来提供另一个抽象层。
最后,通过扩展 SoftDeleteRepository 并提供实体类名称和 id 数据类型作为泛型类型参数来修改主存储库接口。它还为 findById、findAll、deleteById 和 deleteAll 方法提供默认实现,以利用软删除自定义实现定义在 SoftDeleteRepository 接口中。
完成上述步骤后,一切就都准备好了。领域服务层不需要进一步的实现。值得注意的是,控制器和单元测试用例也不需要修改。
要获取所有记录(包括已删除的记录)或已删除的记录,您可以使用如下代码片段所示的查询方法:
软删除是一种有效且灵活的数据管理方法,无需永久删除数据,非常适合需要数据恢复、合规性或历史数据跟踪的应用程序。在本指南中,我们讨论了软删除是什么、它的优点以及如何使用 R2DBC 在 Spring WebFlux 应用程序中实现它。
您可以在 GitHub 上找到完整的源代码
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。