软删除的好处

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. 没有任何事务还需要这个旧版本

相关推荐
正在走向自律1 天前
金仓数据库KingbaseES中级语法详解与实践指南
数据库·oracle·kingbasees·金仓数据库·信创改造
Gofarlic_oms11 天前
Windchill用户登录与模块访问失败问题排查与许可证诊断
大数据·运维·网络·数据库·人工智能
我是小疯子661 天前
Python变量赋值陷阱:浅拷贝VS深拷贝
java·服务器·数据库
Zoey的笔记本1 天前
2026告别僵化工作流:支持自定义字段的看板工具选型与部署指南
大数据·前端·数据库
静听山水1 天前
docker安装starrocks
数据库
学编程的小程1 天前
从“兼容”到“超越”:金仓KESBSON引擎如何借多模融合改写文档数据库规则
数据库
千层冷面1 天前
数据库分库分表
java·数据库·mysql·oracle
DBA小马哥1 天前
金仓数据库引领国产化替代新范式:构建高效、安全的文档型数据库迁移解决方案
数据库·安全·mongodb·dba·迁移学习
企业对冲系统官1 天前
基差风险管理系统日志分析功能的架构与实现
大数据·网络·数据库·算法·github·动态规划
冉冰学姐1 天前
SSM学毕电设信息采集系统74v6w(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·学生管理·ssm 框架应用·学毕电设·信息采集系统