什么是数据库软删除,什么场景下要用软删除?(go GORM硬删除)

文章目录

什么是数据库软删除,什么场景下要用软删除?

go GORM硬删除

使用的是 GORM,默认启用了软删除功能,即通过将 deleted_at 字段设置为非空来标记删除的记录。这就是为什么在执行 db.Delete(&image) 后,实际上只是更新了 deleted_at 字段而不是真正删除记录。

go GORM中想要完全删除记录而不是软删除,可以使用 Unscoped() 方法来删除记录

go 复制代码
	// 删除数据库中的记录
	var image models.UploadImageModel
	err = db.Where("file_name = ?", filename).First(&image).Error
	//如果您使用的是 GORM,默认启用了软删除功能,即通过将 deleted_at 字段设置为非空来标记删除的记录。
	//这就是为什么在执行 db.Delete(&image) 后,实际上只是更新了 deleted_at 字段而不是真正删除记录。
	if err == nil {
		//db.Delete(&image)
		//如果您想要完全删除记录而不是软删除,可以使用 Unscoped() 方法来删除记录。
		db.Unscoped().Delete(&image)
	}

什么是数据库软删除

软删除是一种常见的数据库设计模式,用于标记删除的记录而不是立即从数据库中删除它们。这种设计模式有以下几个常见的原因:

  1. 数据保留:软删除可以保留被删除记录的信息,以备将来需要恢复或进行审计。

  2. 数据完整性:软删除可以保持数据库的完整性,避免破坏关联的数据结构。

  3. 数据恢复:软删除可以方便地恢复被删除的记录,无需从备份中恢复。

  4. 数据审计:软删除可以记录删除操作的时间和操作者,用于审计和追踪。

软删除是根据具体需求和设计选择的一种方式,它提供了一种灵活的方式来管理和维护数据。

什么场景下要用软删除

软删除和硬删除都有各自适用的场景,具体使用哪种方式取决于您的业务需求和数据管理策略。以下是一些常见的场景和建议:

使用软删除的场景:

  1. 数据保留和历史记录:如果您需要保留被删除记录的信息和历史记录,以便将来需要恢复、审计或分析,软删除是一个不错的选择。
  2. 数据关联和完整性:当删除的记录与其他数据存在关联关系时,软删除可以保持数据的完整性,避免破坏关联的数据结构。
  3. 用户误操作的回滚:软删除可以提供一种用户误操作的回滚机制,以便恢复被删除的数据。

使用硬删除的场景:

  1. 数据安全和隐私:如果您处理的是敏感数据或需要保护数据安全和隐私,硬删除可能更适合,以确保数据彻底从数据库中删除,不再可恢复。
  2. 数据容量和性能:如果您的数据库中存在大量的无用数据,硬删除可以释放存储空间,提高数据库的性能。

在实际应用中,可以根据数据的重要性、敏感性、合规性要求以及业务操作流程来确定是否使用软删除或硬删除。具体使用与否应根据您的业务需求和数据管理要求来决定。

相关推荐
胚芽鞘6814 分钟前
关于java项目中maven的理解
java·数据库·maven
Nejosi_念旧1 小时前
解读 Go 中的 constraints包
后端·golang·go
风无雨1 小时前
GO 启动 简单服务
开发语言·后端·golang
小明的小名叫小明1 小时前
Go从入门到精通(19)-协程(goroutine)与通道(channel)
后端·golang
光影少年2 小时前
从前端转go开发的学习路线
前端·学习·golang
斯普信专业组2 小时前
Go语言包管理完全指南:从基础到最佳实践
开发语言·后端·golang
sun0077003 小时前
mysql索引底层原理
数据库·mysql
workflower6 小时前
MDSE和敏捷开发相互矛盾之处:方法论本质的冲突
数据库·软件工程·敏捷流程·极限编程
Tony小周6 小时前
实现一个点击输入框可以弹出的数字软键盘控件 qt 5.12
开发语言·数据库·qt
lifallen6 小时前
Paimon 原子提交实现
java·大数据·数据结构·数据库·后端·算法