当前位置: 首页 > article >正文

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

文章目录

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

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

go GORM硬删除

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

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

	// 删除数据库中的记录
	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. 数据容量和性能:如果您的数据库中存在大量的无用数据,硬删除可以释放存储空间,提高数据库的性能。

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


http://www.kler.cn/a/231394.html

相关文章:

  • [ 网络安全介绍 1 ] 什么是网络安全?
  • go-zero(一) 介绍和使用
  • 详细解析STM32 GPIO引脚的8种模式
  • IO流(九):打印流-字节打印流PrintStream、字符打印流PrintWriter
  • 【c++丨STL】list的使用
  • WTV芯片在智能电子锁语音留言上的应用方案解析
  • 编辑器Zed
  • leetcode 1539.第k个缺失的正整数
  • 信号的处理机制
  • Springboot使用kafka的两种方式
  • SQL 注入 - http头注入之UA头注入探测
  • 数据库管理-第146期 最强Oracle监控EMCC深入使用-03(20240206)
  • 中兴R5300G4服务器查看服务器、主板序列号及硬盘RAID信息
  • Netty源码系列 之 AbstractUnsafe 高低水位线 ChannelOutboundBuffer 源码
  • redis集群配置
  • gcore服务器设置root账号密码登录
  • LeetCode 491 递增序列
  • 行为型设计模式—备忘录模式
  • 正点原子--STM32基本定时器学习笔记(2)
  • canvas绘制横竖坐标轴(带有箭头和刻度)
  • 飞天使-k8s知识点16-kubernetes实操1-pod
  • 堆排序-Python实现
  • 风行智能电视N39S、N40 强制刷机升级方法,附刷机升级数据MstarUpgrade.bin
  • B站UP主实时信息获取展示php源码
  • 详细分析python中的 async 和 await(附Demo)
  • [python]基于opencv实现的车道线检测