时间点如下:
**Time1:** 事务A(Ta)锁定表t_1中id=3的记录
**Time2:** 事务B(Tb)也去尝试锁定表t_1中id=3的记录, 没有获得锁, 线程等待.
**Time3:** Ta查询表t_2中status=0的前一条记录, id=10,并修改该条记录的stauts=1.
**Time4:** Ta提交事务.
**Time5:** Tb获得记录锁,
**Time6:** Tb查询表t_2中status=0的前一条记录, id=10.(这是个问题,为什么在Tb事务中能获得到这条记录?)
**Time7:** Tb修改表t_2中id=10这条记录的status=1时, 没有修改到.因为update语句执行返回的条数为0.抛出异常.
**Time8:** Tb回滚.
mysql 隔离级别 repeatable_read 多个事务间数据重复读的问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- Saleson 2016-07-08 06:11关注
已经查找到原因,并解决.
有兴趣可以查看文章关于Mysql事务REPEATABLE_READ隔离级别下多版本并发控制(MVCC)重复读产生的坑的你踩过么?解决 无用评论 打赏 举报
悬赏问题
- ¥20 模型在y分布之外的数据上预测能力不好如何解决
- ¥15 processing提取音乐节奏
- ¥15 gg加速器加速游戏时,提示不是x86架构
- ¥15 python按要求编写程序
- ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
- ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
- ¥15 opencv图像处理,需要四个处理结果图
- ¥15 无线移动边缘计算系统中的系统模型
- ¥15 深度学习中的画图问题
- ¥15 java报错:使用mybatis plus查询一个只返回一条数据的sql,却报错返回了1000多条