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

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

mvcc是什么,怎么实现的?

先理解几个概念

非锁定的一致性读

mysql到底是怎么解决幻读的?_第1张图片

图中左边为非一致性读部分

【非一致性读】

在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的返回结果都是一样的,因为期间内的数据都没有变化,这样就解决了幻读的问题;

 

你可能感兴趣的:(数据库)