简识MySQL中ReadView、RC、RR的关系

一、背景

在MySQL中,ReadView是事务进行快照读操作时生成的读视图,它用于确定哪些数据对当前事务是可见的。ReadView的生成和属性受MySQL事务隔离级别的影响,特别是RC(Read Committed,读已提交)和RR(Repeatable Read,可重复读)这两个级别。

二、详解

对于ReadView中哪个属性是由MySQL的事务隔离级别RC、RR设置来起作用的,可以明确的是:ReadView的生成时机和更新策略是由事务隔离级别RC和RR来决定的。具体来说:

在RC隔离级别下

  • 每个快照读操作都会生成并获取最新的ReadView。这意味着,在同一个事务中,如果执行了多次快照读操作,那么每次操作都会看到一个可能不同的数据快照,因为每次都会根据当前活跃的事务ID列表来生成新的ReadView。

在RR隔离级别下

  • 同一个事务中的第一个快照读会创建ReadView,之后的快照读获取的都是同一个ReadView。这意味着,在同一个事务中,无论执行多少次快照读操作,它们都会看到一个相同的数据快照,因为ReadView在事务开始后只生成一次,并且不会随着事务的进行而更新。

因此,虽然ReadView本身包含多个属性(如trx_list、up_limit_id、low_limit_id等),但这些属性的值是由事务的快照读操作在生成ReadView时根据当前系统状态确定的。而ReadView的生成时机和更新策略,则是由MySQL的事务隔离级别RC和RR来控制的。

总的来说,事务隔离级别RC和RR通过影响ReadView的生成时机和更新策略,从而决定了事务在执行快照读操作时能够看到的数据快照。

(望各位潘安、各位子健不吝赐教!多多指正!🙏)

相关推荐
派可数据BI可视化13 分钟前
商业智能BI 浅谈数据孤岛和数据分析的发展
大数据·数据库·数据仓库·信息可视化·数据挖掘·数据分析
yong999015 分钟前
C#驱动斑马打印机实现包装自动打印
java·数据库·c#
野犬寒鸦1 小时前
从零起步学习MySQL || 第五章:select语句的执行过程是怎么样的?(结合源码深度解析)
java·服务器·数据库·后端·mysql·adb
QT 小鲜肉1 小时前
【个人成长笔记】Qt 中 SkipEmptyParts 编译错误解决方案及版本兼容性指南
数据库·c++·笔记·qt·学习·学习方法
我是苏苏1 小时前
C#高级:数据库中使用SQL作分组处理4(LAG() 偏移函数)
数据库
wudl55662 小时前
股票300394(天孚通信)2025年4月20日
数据库
IvorySQL2 小时前
PostgreSQL 18 中国贡献者经验分享:开源参与的四点建议
数据库·postgresql·开源
曾凡宇先生2 小时前
openEuler安装jdk,nginx,redis
linux·开发语言·数据库·openeuler
点灯小铭2 小时前
基于单片机的四沟道步进电机玉米补种机设计与实现
数据库·单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
清风6666662 小时前
基于单片机的双机串口通信与数字串存储系统设计
数据库·单片机·mongodb·毕业设计·课程设计·期末大作业