0

0

mysql如何理解插入意向锁_mysql并发插入时的锁机制

P粉602998670

P粉602998670

发布时间:2026-03-12 11:36:45

|

705人浏览过

|

来源于php中文网

原创

插入意向锁仅在REPEATABLE READ隔离级别下生效;READ COMMITTED下因禁用间隙锁而无需该锁,此时无阻塞但存在幻读风险,可通过performance_schema.data_locks确认其是否存在。

mysql如何理解插入意向锁_mysql并发插入时的锁机制

插入意向锁只在 RR 隔离级别下起作用

MySQL 的 INSERT 语句是否加插入意向锁,取决于事务隔离级别。它**只在 REPEATABLE READ 下生效**;在 READ COMMITTED 下,InnoDB 不用间隙锁(Gap Lock),自然也就不需要插入意向锁来协调——此时插入基本不阻塞,但幻读风险上升。

  • SET TRANSACTION ISOLATION LEVEL REPEATABLE READ 是默认值,但线上环境可能被显式改过,务必用 SELECT @@transaction_isolation 确认
  • 如果误设为 READ COMMITTED,你观察 performance_schema.data_locks 就看不到 LOCK_MODE = 'INSERT_INTENTION'
  • DDL 操作(如加索引)或某些 ORM 自动降级隔离级别时,会悄悄绕过插入意向锁机制

怎么确认插入意向锁正在生效

别猜,直接查锁表。MySQL 8.0+ 推荐走 performance_schema.data_locks,比 SHOW ENGINE INNODB STATUS 更精准、可过滤。

  • 先复现阻塞:会话 A 执行 SELECT * FROM t WHERE id > 15 AND id (锁住间隙),会话 B 执行 <code>INSERT INTO t VALUES (20)(被卡住)
  • 新开会话 C,执行:
    SELECT OBJECT_NAME, INDEX_NAME, LOCK_TYPE, LOCK_MODE, LOCK_DATA FROM performance_schema.data_locks WHERE OBJECT_NAME = 't';
  • 找到 LOCK_MODE'INSERT_INTENTION' 的行,LOCK_DATA 显示间隙范围(如 10, 30),说明它正“声明”自己要插进这个空档

为什么两个 INSERT 不互相阻塞,却会被 SELECT ... FOR UPDATE 卡住

插入意向锁本质是「低冲突」的间隙锁,它**不排斥其他插入意向锁,但排斥 Gap Lock 和 Next-Key Lock**。

智川X-Agent
智川X-Agent

中科闻歌推出的一站式AI智能体开发平台

下载
  • 事务 A 插 20、事务 B 插 25 → 各自申请 (10,30) 上的插入意向锁 → 兼容,不阻塞
  • 但事务 C 执行 SELECT ... WHERE id BETWEEN 15 AND 25 FOR UPDATE → 在 (10,30) 上加 X Gap Lock → 与插入意向锁冲突 → A/B 都得等 C 提交
  • 注意:插入意向锁和记录锁(X, REC_NOT_GAP)也不冲突,所以插入完成后加的行锁不会影响已存在的 Gap Lock

容易忽略的坑:唯一索引冲突会跳过插入意向锁

插入意向锁只在「准备插入但记录尚不存在」时申请。一旦碰到唯一键冲突(比如重复主键或唯一索引值),InnoDB 会立刻尝试加记录锁(X Lock)去判断是否存在——这时已经不走插入意向锁路径了。

  • 表有唯一索引 uk_name,事务 A 插 ('alice') 未提交;事务 B 再插 ('alice') → 直接等待 A 的记录锁释放,不是等插入意向锁
  • 这种场景下,data_locks 中看到的是 LOCK_MODE = 'X,REC_NOT_GAP',不是 INSERT_INTENTION
  • 所以“并发插入不阻塞”的前提,是插入的值在索引上互不重叠;否则就退化成普通行锁等待

实际调试时,最常翻车的地方不是锁类型记错,而是忘了查隔离级别、没清空缓存事务、或者把唯一约束冲突当成插入意向锁阻塞来看——结果对着错误的方向调半天。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

513

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

267

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

668

2023.08.14

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 847人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号