✅ MySQL 事务 & MVCC & ROLLBACK


🧠 一、MVCC 与可重复读(REPEATABLE READ)

项目 内容
MVCC 概念 多版本并发控制,事务中读到的是开启事务时的数据快照
实现机制 依赖 Read View + trx_id + Undo Log 实现版本判断
快照读 普通 SELECT,使用 MVCC,不加锁,读取历史版本
当前读 SELECT ... FOR UPDATE / UPDATE,不使用快照,读取当前版本并加锁
默认隔离级别 MySQL InnoDB 默认 REPEATABLE READ,快照在事务首次读时固定
插入型幻读 快照读无法解决,InnoDB 通过"间隙锁(Gap Lock)"解决

🔬 二、实验验证行为(你亲自操作的)

场景描述 验证结果
快照读能否看到别的事务提交的新记录 ❌ 不能,看到的是旧版本
当前读是否能看到别的事务刚提交的记录 ✅ 能看到,当前读不走 MVCC
当前读是否加锁 ✅ 加排他锁,阻塞并发写操作
锁是否在事务中立即释放 ❌ 不会,直到 COMMIT / ROLLBACK 才释放
如何查看锁持有状态 ✅ 用 SHOW ENGINE INNODB STATUS + innodb_trx 查看
performance_schema 能否替代老锁表 ✅ 推荐使用 data_locks 和 data_lock_waits

🔄 三、ROLLBACK 撤销事务

内容点 说明与示例简述
作用 撤销事务内的所有操作,恢复到事务开始前的状态
常见用法 校验失败、异常中断、业务取消、死锁回滚
搭配 SAVEPOINT 实现"部分回滚"逻辑控制
行锁释放 ROLLBACK 会自动释放当前读加的锁
对 DDL 无效 如 ALTER TABLE 会隐式提交,不能被 ROLLBACK 撤销
自动提交下无效 autocommit = 1 时每条语句立即提交,ROLLBACK 无效
底层机制依赖 依赖 Undo Log 回滚数据,不会写 binlog,Redo 不落盘

🔍 四、事务状态排查方法

工具/命令 说明
SHOW ENGINE INNODB STATUS\G 查看当前事务、锁、死锁、读视图等 InnoDB 信息
information_schema.innodb_trx 查看活动事务、事务ID、锁、回滚等
performance_schema.data_locks 替代 innodb_locks,查看当前所有锁持有情况
performance_schema.data_lock_waits 查看事务之间的锁等待关系

📚 五、实操项目(高价值)

  • ✅ 快照读实验(多次 SELECT 结果一致)

  • ✅ 当前读实验(FOR UPDATE 加锁)

  • ✅ 插入新记录事务可见性测试

  • ✅ 锁状态监控与观察

  • ✅ ROLLBACK 撤销事务并释放锁

  • ✅ 配合事务工具查看锁结构

  • ✅ 手动设置事务隔离级别,排查幻读来源


相关推荐
一 乐7 分钟前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
1.14(java)1 小时前
SQL数据库操作:从CRUD到高级查询
数据库
Full Stack Developme2 小时前
数据库索引的原理及类型和应用场景
数据库
IDC02_FEIYA4 小时前
SQL Server 2025数据库安装图文教程(附SQL Server2025数据库下载安装包)
数据库·windows
辞砚技术录4 小时前
MySQL面试题——联合索引
数据库·面试
萧曵 丶4 小时前
MySQL 主键不推荐使用 UUID 的深层原因
数据库·mysql·索引
小北方城市网4 小时前
分布式锁实战指南:从选型到落地,避开 90% 的坑
java·数据库·redis·分布式·python·缓存
毕设十刻5 小时前
基于Vue的人事管理系统67zzz(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
TDengine (老段)6 小时前
TDengine Python 连接器入门指南
大数据·数据库·python·物联网·时序数据库·tdengine·涛思数据
萧曵 丶7 小时前
事务ACID特性详解
数据库·事务·acid