Mysql的锁

表级锁、行级锁、全局锁

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

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

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

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

共享锁和排它锁

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

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

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

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

意向锁

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

记录锁、间隙锁、临键锁

它们都是行锁。

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

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

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

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

相关推荐
keep intensify26 分钟前
杨氏矩阵、字符串旋转、交换奇偶位,offsetof宏
c语言·开发语言·数据结构·算法·矩阵
enyp8028 分钟前
c++ 类和动态内存分配
java·开发语言·c++
春天里的小帆船31 分钟前
4.20刷题记录(单调栈)
开发语言·数据结构
hy____1231 小时前
string类(详解)
开发语言·c++
东阳马生架构1 小时前
Sentinel源码—6.熔断降级和数据统计的实现二
java·sentinel
跟着杰哥学Python1 小时前
一文读懂Python之numpy模块(34)
开发语言·python·numpy
爱吃烤鸡翅的酸菜鱼1 小时前
Java【网络原理】(4)HTTP协议
java·网络·后端·网络协议·http
氦客1 小时前
kotlin知识体系(六) : Flow核心概念与与操作符指南
android·开发语言·kotlin·协程·flow·冷流·热流
无际单片机编程1 小时前
嵌入式C语言位操作的几种常见用法
java·c语言·stm32·单片机·嵌入式硬件
xoxo-Rachel1 小时前
SpringBoot 基本原理
java·spring boot·spring