mysql幻读如何解决_mysql到底是怎么解决幻读的?

mysql到底是怎么解决幻读的?
mvcc是什么,怎么实现的?
先理解几个概念非锁定的一致性读

1c925cf27287d3898e84abd529e62e5a.png


图中左边为非一致性读部分
【非一致性读】
在sql查询的时候,如果发现记录已经被加了X锁,会转而查询当前记录回滚段中最近的快照,读快照不加锁,非常快;
【mvcc】
多版本控制
这里的多版本就是指的回滚段的快照,用来解决幻读的情况,即ABA的问题;
【锁算法】
record:记录锁,单行记录加锁
gap:间隙锁,锁住一个范围
next-key:等于record+gap两者结合
【场景解释】
背景:表:tab,主键=id,索引=user_id
当发生update tab set age = 10 where user_id>10;时候,加锁如下:
1.主键索引id会给id=10的记录加上record行锁
2.索引user_id上会加上gap锁,锁住user_id (10,+无穷大)这个范围
所以,在插入 user_id =100的记录时候会命中第二个索引上加的锁会报出事务异常;
所以在事务中即使查询多次user_id>10的返回结果都是一样的,因为期间内的数据都没有变化,这样就解决了幻读的问题;
转载于https://blog.csdn.net/philip502/article/details/90722780

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值