Mysql的锁

表级锁、行级锁、全局锁

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

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

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

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

共享锁和排它锁

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

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

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

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

意向锁

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

记录锁、间隙锁、临键锁

它们都是行锁。

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

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

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

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

相关推荐
菩提小狗几秒前
SQL注入之sqlmap|web安全|渗透测试|网络安全
数据库·sql·web安全
这里是彪彪2 分钟前
Java中的volatile关键字的作用
java·开发语言
HZZD_HZZD3 分钟前
喜讯|合众致达成功中标G312线傅家窑至苦水公路机电工程FKJD-2标水电表项目
大数据·数据库·人工智能
Dxy12393102166 分钟前
Python的zip用法详解
开发语言·python
逑之7 分钟前
C语言笔记3:分支与循环
c语言·开发语言·笔记
独自破碎E12 分钟前
【归并】数组中的逆序对
java·数据结构·算法
win x14 分钟前
Redis 哨兵模式
数据库·redis·缓存
范什么特西14 分钟前
打开idea项目
java
黎雁·泠崖15 分钟前
Java入门从零起步:CMD操作+JDK环境搭建+第一个Java程序
java·开发语言
f***241115 分钟前
MATLAB高效算法优化实战指南
开发语言·算法·matlab