快照读不用锁靠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语音服务的人工智能开放平台
相关推荐
曹牧7 小时前
Oracle:前缀匹配之REGEXP_LIKEUnbelievabletobe7 小时前
解决了股票api接口盘后数据更新慢的问题lpd_lt9 小时前
AI Coding的常用Prompt技巧小江的记录本9 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)在繁华处9 小时前
Java从零到熟练(三):流程控制asdzx679 小时前
使用 Python 快速提取 PDF 中的表格无情的西瓜皮9 小时前
MCP协议实战:用Python从零搭建一个AI Agent工具服务器(保姆级教程)暴躁小师兄数据学院10 小时前
【AI大数据工程师特训笔记】第05讲:关联查询倔强的石头_10 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战lzhdim10 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析