唯一索引等值查询(条件值存在记录锁,不存在邻居间隙锁)
- 当查询的记录是「存在」的,在索引树上定位到这一条记录后,将该记录的索引中的 next-key lock 会退化成「记录锁」。
- 当查询的记录是「不存在」的,在索引树找到第一条大于该查询记录的记录后,将该记录的索引中的 next-key lock 会退化成「间隙锁」。
唯一索引范围查询(条件值存在大于记录锁,小于不变,不存在邻居之间间隙锁)
- 当唯一索引进行范围查询时,会对每一个扫描到的索引加 next-key 锁。
- 针对「大于和大于等于」的范围查询,存在条件值,条件值的 next-key 锁会退化成记录锁,不存在就在条件值和下个符合条件的记录值之间加间隙锁。
- 针对「小于或者小于等于」的范围查询,存在条件值,小于条件值和上个记录之间加间隙锁,小于等于条件值不转化为间隙锁,不存在时在条件值的前后两个值之间加上间隙锁。
非唯一索引等值查询(条件值存在临键锁,邻居间隙锁,不存在间隙锁)
- 条件值存在时,对条件值加 next-key 锁并在主键索引加记录锁,第一个条件值和上个值之间加临键锁,最后一个条件值和下个值之间加间隙锁。
- 条件值不存在时,在条件值的前后值之间加间隙锁。
非唯一索引范围查询(条件值不存在邻居间隙锁,存在皆为临键锁)
- 条件值不存在,条件值和邻居之间加间隙锁。
- 条件值存在全是临键锁。