锁跟事务有关
一、共享锁(读锁/S锁)
1. 多个事务的查询语句,对同一数据,可以共享一把锁,都能访问到最新数据
2. 如果只有一个事务获取到了一个共享锁,可以更新、删除
3. 如果多个事务都获取到了同一个共享锁,多个事务都不可以更新、删除
4. 使用场景:多个事务都可以获取最新数据
二、排它锁(写锁/X锁)
1. 不能与其他锁共存,只有一个事务能拿到锁
2. 锁释放后,其他事务才能获取
3. 使用场景:一个事务进行查询、更新、删除操作
三、自增锁
1. 如果表中存在自增字段,MySql会自动维护一个自增锁
2. 当事务插入一条数据,自增+1,事务未提交时,查不到这条数据,提交后才能查到
记录锁、间隙锁、临键锁都是排它锁
四、记录锁(行锁)
1. 锁住一行记录
2. 阻止该行被其他事务操作(删除、更新、插入同样的ID)
五、间隙锁
1. 封锁
a. 索引记录中的间隔,例如(1,3], (3,5]等
b. 第一条索引之前的范围,即(-infinity,1]
c. 最后一条索引之后的范围,即(5,infinity]
2. 产生间隙锁的条件
a. 使用普通索引锁定
b. 使用多列唯一索引
c. 使用唯一索引锁定多行记录
3. 只有在事务隔离级别为RR时,才会产生
4. 唯一索引:锁住多条记录,或者不存在的记录时,才会产生间隙锁
5. 普通索引:锁住单条、多条记录,都会产生间隙锁
6. 锁住该条记录相邻的两个键之间的空白区域,防止其他事务在这个范围内插入、修改、删除
7. 防止出现幻读
8. 如果事务隔离级别是RC,间隙锁将会失效
六、临键锁
记录锁和间隙锁的组合,既包含索引记录,又包含索引区间
参考:
https://zhuanlan.zhihu.com/p/48127815
https://zhuanlan.zhihu.com/p/48207652
https://zhuanlan.zhihu.com/p/48269420
标签:事务,删除,记录,间隙,锁住,索引,MySql,机制 来源: https://www.cnblogs.com/june0816/p/6803733.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。