【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可减少间隙锁的使用。
相关推荐
jiayou644 小时前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北5 小时前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤1 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12022 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip