技术文摘
MySQL MVCC 中 update 后 select 仍能读到数据的原因
MySQL MVCC 中 update 后 select 仍能读到数据的原因
在使用 MySQL 数据库时,很多开发者会遇到这样的疑惑:执行 update 操作后,使用 select 语句却依然能够读到更新前的数据。这一现象背后的原理与 MySQL 的多版本并发控制(MVCC)机制紧密相关。
MVCC 是一种用于在数据库中实现高并发读操作的机制,它允许事务在不锁定数据行的情况下读取数据的不同版本。这大大提高了数据库的并发性能,减少了锁争用。
当执行 update 语句时,MySQL 并不会直接覆盖原有数据。实际上,它会创建一个新版本的数据行,并将旧版本的数据行标记为过期。在事务提交之前,旧版本的数据行依然存在,并且对于其他未提交的事务而言,它仍然是可见的。
在执行 select 语句时,MySQL 根据事务的隔离级别来决定读取哪个版本的数据。例如,在“读已提交”隔离级别下,事务只能读取已经提交的数据。但是,如果一个事务在 update 操作之后,另一个事务在该 update 事务提交之前执行 select 操作,那么这个 select 操作将会读取到旧版本的数据。这是因为 MVCC 机制保证了在事务提交之前,旧版本的数据行对于其他事务来说仍然是可见的。
而在“可重复读”隔离级别下,一个事务在启动时会创建一个“一致性视图”,该视图会记录当时所有活跃事务的情况。在整个事务执行过程中,所有的 select 操作都会基于这个一致性视图来读取数据,即使在事务执行过程中有数据被更新,该事务仍然会读取到事务启动时的数据版本。
MySQL MVCC 机制中 update 后 select 仍能读到数据,主要是因为 MVCC 允许读取旧版本的数据,并且事务隔离级别决定了在不同情况下事务能够看到的数据版本。理解这一机制对于优化数据库性能、避免数据不一致性问题具有重要意义。
TAGS: update操作 SELECT查询 MySQL MVCC 数据读取原因
- 多线程异步【日志系统】高效强悍的双缓冲实现
- 50 行代码轻松实现敏感数据读写
- JavaScript 中变量、作用域与内存问题的深度解读
- 你会解新面试题回文链表吗?
- 高并发 HTTP 请求的实践探索
- HDC 技术分论坛:深入剖析 HarmonyOS 新一代 UI 框架
- HarmonyOS ArkUI 3.0 开发实战:轻松合成 1024
- 鸿蒙分布式跨设备文件服务下的信件管理
- 2021 年,不应再将 x86 和 ARM 归为 CISC 和 RISC
- GitHub 全球开发者大会举行!产品改进达 20000 处,Copilot 迎来重磅更新
- 数据科学项目的六个解决技巧
- 微软推出可于浏览器中完全运行的轻量级 VS Code 工具
- 一个 Nest.js 上手项目:虽丑却宜练手与收藏
- 动态规划,你期待的它来了
- 面试官:解析 Casbin 配置文件中的设计理念