news 2026/4/3 6:12:49

软删除的好处

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
软删除的好处

1.问题

比如关注表,当关注时插入一行,取观时只是将delete列设置为1,并没有把这一行删除,为什么要这么做?为什么要update,而不是delete?为什么使用了软删除(逻辑删除),而不是硬删除(物理删除)?

2.原因

  1. 有可能取关后又再关注,会导致频繁插入删除;
  2. 大量delete可能会有性能问题,会产生undo log,delete存储的是本行所有列的数据,log文件会更大;产生索引碎片。

2.1 对索引的影响

DELETE一行 不会立刻重建主键索引,但会 造成 B+Tree 的“空洞 / 碎片”,长期大量 DELETE → 主键索引效率下降。

在 InnoDB 中:主键索引 = 聚簇索引,数据行本身就存放在 B+Tree 的叶子节点里

也就是说:

删一行 ≈ 从主键 B+Tree 里“挖掉一个叶子记录”

长期后会变成:

同样数量的有效数据
需要扫描更多的索引页

update操作的是非索引字段,没有这方面的影响。

2.2 索引重建时机

只有这些情况:

  • OPTIMIZE TABLE

  • ALTER TABLE ... ENGINE=InnoDB

  • ALTER TABLE重建

  • 导出再导入

这些操作:

  • 会重建聚簇索引

  • 会锁表 / 占资源

  • 不可能频繁在线执行

👉 所以线上系统靠设计避免 DELETE,而不是事后 OPTIMIZE。

2.3 undo log撤销日志

Undo log 的核心作用只有两个:

1️⃣支持事务回滚(Rollback)
2️⃣支持 MVCC,让读不被写阻塞

它本质上是:
👉“把你这次修改之前的旧数据存下来”

对不同操作,undo log 内容不同:

✅ INSERT

  • undo log 记录:“这行需要被删掉”

✅ DELETE

  • undo log 记录:“这行原本长什么样”

  • 回滚时:恢复整行

✅ UPDATE

  • undo log 记录:被修改字段的旧值

  • 回滚时:改回去

⚠️ 注意重点:

UPDATE deleted=1 只记录 deleted 的旧值(0)

同时,undo log能避免脏读,一个事务未提交之前,另一个线程看不到它的修改。

undo log清理:

✅ 1. 事务已经提交 / 回滚

✅ 2.没有任何事务还需要这个旧版本

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/16 10:39:07

ioredis 5.x:重新定义Node.js与Redis的高性能交互方式

ioredis 5.x:重新定义Node.js与Redis的高性能交互方式 【免费下载链接】ioredis 一款强大、注重性能且功能齐全的Redis客户端,它是专门为Node.js设计和构建的。这款客户端旨在为使用Node.js开发的应用提供与Redis数据库高效、稳定及全面交互的能力。 项…

作者头像 李华
网站建设 2026/3/30 19:55:36

5步构建高可靠性HTTP性能测试体系:Boom工具深度实践指南

5步构建高可靠性HTTP性能测试体系:Boom工具深度实践指南 【免费下载链接】boom HTTP(S) load generator, ApacheBench (ab) replacement, written in Go 项目地址: https://gitcode.com/gh_mirrors/bo/boom 在现代分布式系统架构中,HTTP接口性能直…

作者头像 李华
网站建设 2026/4/1 12:40:07

好写作AI:答辩PPT速成!基于论文内容,AI一键生成清晰演示大纲

论文洋洋洒洒几万字,答辩PPT该如何取舍?别慌,让AI当你的“内容策展人”!当论文写作终于画上句号,下一个让人头大的挑战接踵而至:答辩PPT怎么做? 面对自己心血凝结的数万文字,如何提炼…

作者头像 李华
网站建设 2026/3/26 18:43:46

解锁多模态AI新境界:CLIP ViT-B/32模型部署全解析

解锁多模态AI新境界:CLIP ViT-B/32模型部署全解析 【免费下载链接】ViT-B-32__openai 项目地址: https://ai.gitcode.com/hf_mirrors/immich-app/ViT-B-32__openai 在人工智能快速发展的今天,多模态模型正成为连接视觉与语言世界的桥梁。CLIP Vi…

作者头像 李华
网站建设 2026/3/20 20:52:44

手把手教你用Lora微调Qwen3-VL模型实现LaTeX公式OCR识别

手把手教你用Lora微调Qwen3-VL模型实现LaTeX公式OCR识别 【免费下载链接】self-llm 项目地址: https://gitcode.com/GitHub_Trending/se/self-llm 还在为复杂的数学公式识别而烦恼吗?今天我们就一起来探索如何通过Lora微调技术,让Qwen3-VL模型在…

作者头像 李华