【mysql】锁机制 - 2.行锁间隙锁临键锁

MySQL 锁机制详解(行锁、间隙锁、临键锁)

行锁(Record Lock)

行锁是作用于索引记录上的锁,确保事务对某一行数据的独占访问。行锁分为共享锁(S锁)和排他锁(X锁):

  • 共享锁(S锁):允许其他事务读取被锁定的行,但禁止修改。
  • 排他锁(X锁):禁止其他事务读取或修改被锁定的行。

行锁的实现依赖索引,如果没有索引,InnoDB会隐式创建隐藏的聚簇索引来加锁。

间隙锁(Gap Lock)

间隙锁锁定的是索引记录之间的间隙,防止其他事务在间隙中插入数据,解决幻读问题。间隙锁仅在REPEATABLE READ隔离级别下生效。

间隙锁的特点:

  • 仅作用于非唯一索引或范围查询。
  • 间隙锁之间不互斥,允许不同事务在同一间隙上加锁。
  • 间隙锁会阻塞插入操作,但不影响其他事务在已有记录上加锁。

示例场景:

sql 复制代码
-- 事务A执行范围查询,对(5,10)间隙加锁
SELECT * FROM table WHERE id BETWEEN 5 AND 10 FOR UPDATE;

-- 事务B尝试在间隙中插入数据会被阻塞
INSERT INTO table (id) VALUES (7);
临键锁(Next-Key Lock)

临键锁是行锁与间隙锁的组合,锁定索引记录及其之前的间隙。它是InnoDB默认的行锁算法,结合了防止幻读和确保数据一致性的能力。

临键锁的规则:

  • 对于唯一索引的等值查询,退化为行锁。
  • 对于非唯一索引或范围查询,锁定匹配的行及相邻间隙。

示例:

sql 复制代码
-- 表中存在id=5和id=10的记录
-- 事务A锁定id=5的行及(5,10)间隙
SELECT * FROM table WHERE id = 5 FOR UPDATE;

-- 事务B无法插入id=6或修改id=5
INSERT INTO table (id) VALUES (6);
UPDATE table SET name='test' WHERE id=5;
锁的兼容性
锁类型 X(排他锁) S(共享锁) Gap(间隙锁)
X 冲突 冲突 冲突
S 冲突 兼容 兼容
Gap 冲突 兼容 兼容
优化建议
  • 尽量使用唯一索引减少锁范围。
  • 避免大事务,减少锁持有时间。
  • 合理选择隔离级别,READ COMMITTED可减少间隙锁的使用。
相关推荐
0xDevNull4 小时前
MySQL数据冷热分离详解
后端·mysql
科技小花4 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸4 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain4 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希5 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神5 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员5 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java5 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿5 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴5 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存