获得徽章 0
看完美团、字节、腾讯这三家的一二三面试问题,是不是感觉问的特别多[呲牙][呲牙][呲牙],可能咱们真的又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。

我可是足足背下了 Java互联网工程师面试1000题 ,多少还是有点用的呢,换汤不换药,不管面试官怎么问你,抓住本质即可!

算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题,没有的可以点击此处免费领取[奋斗]
展开
1
什么是幻读?

幻读指的是一个事务在前后两次查询同一个范围的时候,后一次查询看到了前一次查询没有看到的行。

首先快照读是不存在幻读的,只有当前读(实时读)才存在幻读的问题。

幻读有什么问题?

select ...for update语句就是将相应的数据行锁住,但是如果存在幻读,就把for update的语义破坏了。

如何解决幻读?

产生幻读的原因是,行锁只能锁住行,但是新插入记录这个动作,要更新的是记录之间的“间隙”。因此,为了解决幻读问题,InnoDB只好引入新的锁,也就是间隙锁(Gap Lock)。间隙锁和行锁合称next-key lock,每个next-key lock是前开后闭区间。

总结

RR(可重复读)隔离级别下间隙锁才有效,RC(提交读)隔离级别下没有间隙锁;
RR隔离级别下为了解决“幻读”问题:“快照读”依靠MVCC控制,“当前读”通过间隙锁解决;
间隙锁和行锁合称next-key lock,每个next-key lock是前开后闭区间;
间隙锁的引入,可能会导致同样语句锁住更大的范围,影响并发度。
展开
评论
下一页
个人成就
文章被点赞 256
文章被阅读 52,847
掘力值 2,787
收藏集
1
关注标签
19
加入于