MySQL如何通过MVCC提升并发读性能_理解undo log版本链

快照读不用锁靠Undo Log版本链实现,SELECT通过ReadView沿DB_ROLL_PTR链追溯可见版本;ReadView用m_up_limit_id、m_low_limit_id和m_creator_trx_id三值判断版本可见性。快照读为什么不用锁?靠的是Undo Log版本链MySQL的SELECT不加锁,不是"放任不管",而是把一致性判断逻辑从"加锁阻塞"搬到了"按需追溯旧版本"。核心在于:每行数据通过DB_ROLL_PTR连成一条单向链表,链上的每个节点都是该行在某个事务修改前的快照,物理存储在Undo Log里。每次UPDATE或DELETE都会生成新版本,并把DB_TRX_ID设为当前事务ID,DB_ROLL_PTR指向上一个Undo Log记录读操作不查最新行,而是拿着自己的ReadView,沿着版本链往前找------第一个满足可见性规则的版本就是它该看到的数据这意味着:100个并发SELECT可以同时遍历同一条版本链,互不干扰;而UPDATE只管追加新版本,完全不碰旧版本的内存或磁盘位置ReadView怎么决定哪个版本"可见"?关键看三个IDReadView不是时间戳,也不是快照副本,而是一组事务ID边界值。它的判断逻辑直接决定你查到的是"刚提交的新值"还是"事务开始时的老值"。m_up_limit_id(低水位):小于它的事务ID,一定已提交 → 对当前事务可见m_low_limit_id(高水位):大于等于它的事务ID,一定未提交或正在运行 → 不可见m_creator_trx_id:当前事务自己的ID → 自己改的数据永远可见若某行的DB_TRX_ID落在中间区间,就顺着DB_ROLL_PTR继续往上翻版本链,直到找到一个DB_TRX_ID m_up_limit_id的节点,或链尾RC和RR隔离级别差异,全在ReadView创建时机同一个SQL,在READ COMMITTED下可能每次SELECT都看到新结果,在REPEATABLE READ下却始终不变------这不是缓存,是ReadView复用导致的版本链截断点不同。 标贝科技 标贝科技-专业AI语音服务的人工智能开放平台

相关推荐
2401_835956812 小时前
Python Web应用负载均衡方案_结合Nginx权重设置实现高可用
jvm·数据库·python
yfhmmm2 小时前
【无标题】
数据库·postgresql
爆更小哇2 小时前
pytest集成Allure报告教程
python·测试工具·pytest·接口测试·allure
zhanghongyi_cpp2 小时前
6. 【分支-章测-编程-2】土壤PH值测定与土壤改良策略
python
2401_871696522 小时前
CSS如何制作点击展开时的手风琴动画_平滑过渡max-height高度
jvm·数据库·python
Greyson12 小时前
C#怎么使用属性Property C#自动属性和完整属性的区别get set怎么用【基础】
jvm·数据库·python
派葛穆2 小时前
Python-OpenCV打开海康机器人黑白相机
python·opencv·机器人
Deitymoon3 小时前
嵌入式数据库——API创建
数据库·sql
m0_746752303 小时前
c++怎么利用std--variant处理多种二进制子协议包的自动分支解析【进阶】
jvm·数据库·python