导读:本期聚焦于小伙伴创作的《MySQL中意向锁IS和IX是什么?多粒度锁冲突该如何分析》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《MySQL中意向锁IS和IX是什么?多粒度锁冲突该如何分析》有用,将其分享出去将是对创作者最好的鼓励。

MySQL InnoDB引擎支持多粒度锁定机制,既可以对行加锁,也可以对表加锁,意向锁就是为了实现多粒度锁之间的快速冲突判断而设计的锁类型,分为意向共享锁IS和意向排他锁IX两类。

MySQL中意向锁IS和IX是什么?多粒度锁冲突该如何分析

意向锁的核心作用

如果没有意向锁,当一个事务想要对整张表加表级锁时,需要逐行检查表中是否有行级锁存在,这个过程的性能开销会随着表数据量增大而急剧上升。意向锁的作用就是在事务对行加锁之前,先对表级添加一个对应的意向锁标记,这样其他事务想要加表级锁时,只需要检查表的意向锁即可快速判断是否存在冲突,不需要逐行扫描。

简单来说,意向锁是表级锁,但是它的存在是为了协调行级锁和表级锁的关系,本身不会阻塞除全表扫描以外的普通读写操作。

意向锁的触发规则

意向锁不需要用户手动添加,是InnoDB引擎自动管理的,触发规则如下:

  • 当事务需要对表中的某些行加共享锁S时,会先自动给表加意向共享锁IS
  • 当事务需要对表中的某些行加排他锁X时,会先自动给表加意向排他锁IX

多粒度锁冲突矩阵

不同锁类型之间的兼容性可以通过下面的冲突矩阵判断,兼容表示可以同时存在,不兼容表示会产生阻塞:

锁类型ISIXSX
IS兼容兼容兼容不兼容
IX兼容兼容不兼容不兼容
S兼容不兼容兼容不兼容
X不兼容不兼容不兼容不兼容

从矩阵可以看出,意向锁之间是完全兼容的,意向锁和行级锁的兼容性取决于行级锁的类型,只有表级排他锁X会和所有意向锁冲突,表级共享锁S只会和IX锁冲突。

实际案例分析

下面通过两个事务的操作案例,分析意向锁的冲突场景,首先创建测试表并插入数据:

-- 创建测试表
CREATE TABLE test_lock (
    id INT PRIMARY KEY,
    name VARCHAR(20)
) ENGINE=InnoDB;

-- 插入测试数据
INSERT INTO test_lock VALUES (1, 'test1'), (2, 'test2');

案例1:IX锁和S锁的冲突

开启两个事务,按照以下顺序执行:

-- 事务1
START TRANSACTION;
-- 对id=1的行加排他锁,会自动给表加IX锁
SELECT * FROM test_lock WHERE id=1 FOR UPDATE;

-- 事务2
START TRANSACTION;
-- 尝试给表加共享锁,需要检查表的IX锁,会产生阻塞
LOCK TABLES test_lock READ;

此时事务2会被阻塞,因为表的IX锁和要加的S锁不兼容,直到事务1提交释放IX锁,事务2才能获取到表级S锁。

案例2:IS锁和IX锁的兼容

-- 事务1
START TRANSACTION;
-- 对id=1的行加共享锁,自动加IS锁
SELECT * FROM test_lock WHERE id=1 LOCK IN SHARE MODE;

-- 事务2
START TRANSACTION;
-- 对id=2的行加排他锁,自动加IX锁,和IS锁兼容,不会阻塞
SELECT * FROM test_lock WHERE id=2 FOR UPDATE;

这个场景中事务2可以正常执行,因为IS和IX锁是兼容的,不会互相阻塞。

如何查看意向锁信息

当遇到锁等待问题时,可以通过MySQL的information_schema库下的锁相关表查看意向锁信息:

-- 查看当前锁信息,包含意向锁
SELECT * FROM information_schema.INNODB_LOCKS;
-- 查看锁等待信息
SELECT * FROM information_schema.INNODB_LOCK_WAITS;

在查询结果中,lock_type为TABLE的就是意向锁,lock_mode字段会显示IS或者IX,结合冲突矩阵就可以快速判断锁冲突的原因。

总结

意向锁是InnoDB多粒度锁机制的重要组成部分,IS和IX锁的存在大幅提升了表级锁和行级锁的冲突判断效率。分析多粒度锁冲突时,只需要对照冲突矩阵,先确定涉及的锁类型,再判断兼容性即可。日常开发中遇到锁相关问题时,优先查看当前的锁类型和等待关系,结合意向锁的触发规则就能快速定位问题根源。

MySQL意向锁IS_锁IX_锁多粒度锁修改时间:2026-06-28 08:03:24

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。