mysql 行锁为什么不能阻止幻读?

6 篇文章 0 订阅

首先要知道什么是幻读。
幻读指的是一个事务在前后两次查询同一个范围的时候,后一次查询看到了前一次没有看到的行。
比如下图的3个session 中
T1,T3,T5 查询的结果都不一样。
T3 属于不可重复读。
T5 就是幻读 因为T4刚插入了 一条数据在这里插入图片描述

我们把数据库调成REPEATABLE READ重复读在执行一次会出现如下
REPEATABLE READ

由于 session A 把所有的行都加了写锁,所以 sessionB 在执行第一个update 语句的时候就锁住了,需要T6时刻提交后sessionB才能执行.所以T3 属于不可重复读 的问题解决了。

但是T5的幻读还存在,因为在T3时刻我们给所有的行都加了锁,但是新插入的行不存在,所以没发加锁。
也就是说,即使把所有记录都加上锁,也无法阻止新插入的记录。

这就是为什么mysql行锁解决方案无法阻止幻读。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值