【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可减少间隙锁的使用。
相关推荐
定偶6 分钟前
mysql
c语言·数据库·mysql
Gold Steps.16 分钟前
MySQL Operator for Kubernetes自动实现整个生命周期
mysql·云原生·kubernetes
Nandeska27 分钟前
10、MySQL8.0新增特性
数据库·mysql
未来之窗软件服务38 分钟前
计算机等级考试—KTV 管理系统数据流图大题—东方仙盟练气期
数据库·计算机软考·仙盟创梦ide·东方仙盟
云草桑1 小时前
.net AI开发04 第八章 引入RAG知识库与文档管理核心能力及事件总线
数据库·人工智能·microsoft·c#·asp.net·.net·rag
diediedei1 小时前
机器学习模型部署:将模型转化为Web API
jvm·数据库·python
m0_561359671 小时前
使用Python自动收发邮件
jvm·数据库·python
天空属于哈夫克31 小时前
企业微信外部群运营升级:API 主动推送消息开发实战
java·数据库·mysql
naruto_lnq1 小时前
用Python批量处理Excel和CSV文件
jvm·数据库·python
星火开发设计1 小时前
共用体 union:节省内存的特殊数据类型
java·开发语言·数据库·c++·算法·内存