news 2026/5/16 10:42:10

为什么不采用级联删除而选择软删除

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
为什么不采用级联删除而选择软删除

在数据库设计中,如果涉及级联删除的问题,不要通过外键的方式来进行操作,需要使用事务的方式来进行操作,为什么不采用外键的方式主要有以下两点:

  1. 在数据库中,外键会关联主键,在主键进行删除的同时会导致相关的外键也会将数据进行删除,此时有一个很大的问题就是外键删除,外键删除会导致如果出现删除异常,会导致有错误数据,系统逻辑会有问题,所以在进行删除时必须要设计成放到一个事务中进行相关联的删除。
  2. 在使用外键删除时,删除主键会导致所有相关外键数据删除,此时会导致另一个严重问题是索引重建,这种是指级联删除时代价堪比索引重建,并非是重新构建表时的索引重建。

在数据库中,外键会关联主键,所以说在操作数据库的过程中,我们需要做到不要使用外键,因为越是大的系统对于性能的要求就更高,相应的如果数据库操作使用外键可能将磁盘io全部打满,导致系统性能下降,所以说在构建时不要使用外键这种情况,可以使用字段的方式进行删除。

级联删除的索引重建:

因为数据库存储是通过b+树来分页索引存储数据进行实现,每个索引页下面的空数据超过了50%,则会进行页合并,页合并会涉及后面整个子树结构的调整,其中在调整时为了保证不出错会出现数据库上锁,此时就不能进行数据库其他操作,就会显得数据库效能极差,用户体验感也差。而且在进行主键删除时会删除相关的数据,这些数据存在不同的页下面,就可能会让多个索引页进行调整。所以这种级联删除的操作成本非常高,而且不具备可控性。

所以我们在设计时就要采用软删除+定期清理的方式来处理这个问题!!!

数据库删除策略对比图:

为什么要采用软删除+定期清理呢?

  1. 软删除+定期清理的方式可控,在进行定期删除时可以根据脚本设定批量控制删除的数据量多少,这样能够防止一次性全部删除数据之后数据库的索引重构的代价。
  2. 定期清理的方式可以采用在业务不繁忙的时间段采用定时任务来进行实现,这样的话可以增强用户体验感,防止在高频使用时间段来进行删除导致进行索引调整后占用数据库资源。
  3. 减少锁的竞争,批量删除后可能会有部分索引重构,会有数据库操作锁的竞争,所以在定期清理的批量删除时,可以采用多批次删除,在每一次批量删除时进行sleep一小段时间,防止全流程占用,在单批量完成之后的sleep时间段可以进行其他数据库相关操作提高用户体验感。
  4. 软删除时需要放到事务中进行,因为这是一整个不可分割的完成的操作。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/15 2:00:41

K8S-组件介绍

一、概述 Kubernetes 简称 k8s,是支持云原生部署的一个平台,起源于谷歌。谷歌早在十几年之前就对其应用,通过容器方式进行部署。 k8s 本质上就是用来简化微服务的开发和部署的,关注点包括自愈和自动伸缩、调度和发布、调用链监控…

作者头像 李华
网站建设 2026/5/10 16:43:02

碳化硅在固态断路器中的应用

在全球能源转型与新型电力系统建设的双重驱动下,直流配电、新能源并网、电动汽车快充等领域对电路保护设备的响应速度、可靠性与能效水平提出了严苛要求。传统机械断路器因响应迟缓、电弧烧蚀、寿命有限等固有缺陷,已难以适配现代电力系统的发展需求。固…

作者头像 李华
网站建设 2026/4/18 10:51:05

遇到“视频格式兼容性问题”别着急!这5款免费工具帮你轻松搞定

在日常处理视频素材或下载经典电影时,你是否遇到过这样的困扰:文件体积巨大占满硬盘,或者传输到手机和iPad上却无法播放?这些视频往往是以AVI格式存在的。虽然AVI是视频领域的元老,但在移动互联网时代,它的…

作者头像 李华
网站建设 2026/5/1 11:19:24

基于Seed-Coder-8B-Base的代码生成服务在云上GPU的部署实践

基于Seed-Coder-8B-Base的代码生成服务在云上GPU的部署实践 在现代软件研发节奏日益加快的背景下,开发者对智能编程辅助工具的需求已从“锦上添花”演变为“刚需”。尤其是在大型项目中频繁出现的模板代码、接口定义和单元测试编写等重复性任务,正逐步被…

作者头像 李华