【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可减少间隙锁的使用。
相关推荐
廿一夏5 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim6 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室7 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)7 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
敲个大西瓜7 小时前
Java项目常用数据归档方式
mysql
YOU OU8 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng9 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
kyriewen9 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
小码工作室10 小时前
使用 HAVING 进行 MySQL 集合筛选
mysql
罗超驿10 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试