• MySql锁机制


    一、锁跟事务有关

    mysql默认的事务隔离级别是:可重复读(RR)

    二、共享锁(读锁/S锁)

    1. 多个事务的查询语句,对同一数据,可以共享一把锁,都能访问到最新数据

    2. 如果只有一个事务获取到了一个共享锁,可以更新、删除

    3. 如果多个事务都获取到了同一个共享锁,多个事务都不可以更新、删除

    4. 使用场景:多个事务都可以获取最新数据

    三、排它锁(写锁/X锁)

    1. 不能与其他锁共存,只有一个事务能拿到锁

    2. 锁释放后,其他事务才能获取

    3. 使用场景:一个事务进行查询、更新、删除操作

    四、自增锁

    1. 如果表中存在自增字段,MySql会自动维护一个自增锁

    2. 当事务插入一条数据,自增+1,事务未提交时,查不到这条数据,提交后才能查到

    五、记录锁(行锁)

    1. 锁住一行记录

    2. 阻止该行被其他事务操作(删除、更新、插入同样的ID)

    六、间隙锁(gap lock)

    1. 概念

    a. 索引记录中有间隔,例如id字段上建了索引,表里有3条记录,id分别为1,3,5

    b. 两条记录之间的间隔(1,3], (3,5]

    c. 第一条索引之前的范围,即(-infinity,1]

    d. 最后一条索引之后的范围,即(5,infinity]

    e. 这种间隔或者范围之间的锁,叫做间隙锁,间隙是前开后闭原则

    f. 间隙锁的作用:间隙内的数据,即一定范围内的数据,在锁定情况下,不发生变化

    2. 产生间隙锁的条件

    a. 使用普通索引锁定

    b. 使用多列唯一索引

    c. 使用唯一索引锁定多行记录

    3. 只有在事务隔离级别为RR时,才会产生

    4. 唯一索引:锁住多条记录,或者不存在的记录时,才会产生间隙锁

    5. 普通索引:锁住单条、多条记录,都会产生间隙锁

    6. 锁住该条记录相邻的两个键之间的空白区域,防止其他事务在这个范围内插入、修改、删除

    7. 防止出现幻读,幻读是因为新增或更新操作,范围查询会出现数据不一致的问题

    8. 如果事务隔离级别是RC,间隙锁将会失效

    七、临键锁(next-key lock)

    1. 记录锁和间隙锁的组合,既包含索引记录,又包含索引区间

    2. 记录锁、间隙锁、临键锁都是排它锁

    参考:

    https://www.jianshu.com/p/32904ee07e56

    https://zhuanlan.zhihu.com/p/48127815

    https://zhuanlan.zhihu.com/p/48207652

    https://zhuanlan.zhihu.com/p/48269420

  • 相关阅读:
    第61课 智能指针类模板
    第60课 数组类模板
    第59课 类模板深度剖析
    第58课 类模板的概念和意义
    第57课 深入理解函数模板
    第56课 函数模板的概念和意义
    第55课 经典问题解析(四)
    155. Min Stack
    141. Linked List Cycle
    136. Single Number
  • 原文地址:https://www.cnblogs.com/june0816/p/6803733.html
Copyright © 2020-2023  润新知