[2025.2.1 MySQL学习] MVCC

MVCC

基本概念

  • 当前读(直接读取数据页最新版本):读取的是记录的最新版本,读取时还要保证其他并发事务不能修改当前记录,会对读取的记录进行加锁。对于一些日常操作,如:select...lock in share mode、select ... for update、update、isnert、delete都是一种当前读

  • 快照读:简单的select(不加锁)就是快照读,读取的是记录数据的可见版本,可能是历史数据,不加锁,是非阻塞读

    • RC:每次select,都生成一个快照读
    • RR:开启事务后第一个select语句才是快照读的地方
    • Serializable:快照读会退化为当前读
  • MVCC(Multi-Version Concurrency Control),多版本并发控制。指维护一个数据的多个版本,使得读写操作没有冲突,快照读为MySQL实现MVCC提供了一个非阻塞读功能。MVCC具体实现,需要依赖于数据库记录中的三个隐式字段、undo log日志、readView






记录隐藏字段

image






undo log

  • 当insert时,产生的undo log只在回滚时需要,在事务提交后,可被立即删除(Insert前,该条数据不存在)
  • update、delete时,产生的undo log不仅回滚时需要,快照读时也需要,不会被立即删除





undo log版本链

image

  • 不同事务或相同事务对同一条记录进行修改,会导致该记录的undo log生成一条记录版本链表,链表的头部是最新的旧记录,链表尾部是最早的旧记录





readview

快照读SQL执行时MVCC提取数据的依据,记录并维护系统当前活跃的事务(未提交的)id,包含四个核心字段:

image

版本数据链访问规则

image

  • RC:在事务中每一次执行快照读时生成ReadView
  • RR:仅在事务第一次执行快照读时生成ReadView,后续复用该ReadView
posted @   Luna-Evelyn  阅读(8)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构

阅读目录(Content)

此页目录为空

点击右上角即可分享
微信分享提示