Mysql的锁

表级锁、行级锁、全局锁

表级锁:锁住一整张表,针对非索引字段加的锁,sql没有用到索引就会使用全局锁,性能较低。

行级锁:针对索引字段加的锁,会锁住一行记录,并发性能高。

全局锁:锁住一整个库,让数据库处于只读状态,一般在数据备份时用到。

当update、delete的时候没有命中唯一索引或者索引失效,会走全表扫描加上表锁,性能很低。

共享锁和排它锁

表锁和行锁都由共享锁和排它锁。

共享锁又称读锁,允许多个事务同时读取数据。

排它锁又称写锁,在修改操作时会获取排他锁,排它锁之间是互斥的,同时只允许一个事务获取。

共享锁之间不互斥,共享锁与排它锁互斥,排它锁之间是互斥的。

意向锁

意向锁是表锁,主要作用是在我们需要对整张表加表锁的时候,由于表锁和行锁是互斥的,如果去一行一行的检查有没有行锁,那么效率很低,所以当我们去加行锁的时候同时会加上一个意向锁,当要加表锁的时候检查到有意向锁,就知道某行记录加了行锁,也就不用一行行的去检查了。

记录锁、间隙锁、临键锁

它们都是行锁。

记录锁:对单个记录加锁。

间隙锁:锁定记录之间的间隙,不包括记录。

临键锁:记录锁+间隙锁,锁定一个范围,包括记录本身。主要是为了解决幻读问题。

临键锁是RR隔离级别下用于防止幻读的措施,当select...for update,select...for lock in share mode 去范围查询时,或者查询条件是非唯一索引查出多行记录时就会产生临键锁,防止插入导致幻读。

相关推荐
tung tung tung sahur7 分钟前
领略 Rust 抽象之美:自定义迭代器实现全解析
开发语言·后端·rust
ftpeak13 分钟前
《Rust MP4视频技术开发》第八章:生成MP4
开发语言·rust·音视频·mp4
王道长服务器 | 亚马逊云22 分钟前
帝国CMS + AWS:老牌内容系统的新生之路
服务器·网络·数据库·云计算·aws
程序猿小蒜28 分钟前
基于springboot的校园社团信息管理系统开发与设计
java·前端·spring boot·后端·spring
兔兔爱学习兔兔爱学习30 分钟前
Spring Al学习9:模型上下文协议(MCP)
java·学习·spring
m0_7482480231 分钟前
Spring MVC中@RequestMapping注解的全面解析
java·spring·mvc
Mos_x32 分钟前
28.<Spring博客系统⑤(部署的整个过程
java·后端
爱淋雨的鼬先生33 分钟前
SpringBoot 概述
java·spring boot·后端
好学且牛逼的马34 分钟前
【SSM框架 | day25 spring IOC 与 DI 注解开发】
java·开发语言
shepherd12638 分钟前
破局延时任务(下):Spring Boot + DelayQueue 优雅实现分布式延时队列(实战篇)
java·spring boot·分布式