0

0

mysql意向锁是做什么的_mysql锁协作机制说明

P粉602998670

P粉602998670

发布时间:2026-01-10 00:39:14

|

434人浏览过

|

来源于php中文网

原创

意向锁是InnoDB多粒度锁机制的基础设施,事务执行SELECT...FOR UPDATE或LOCK IN SHARE MODE时自动在表级加IX或IS锁,用于快速判断表中是否存在行锁,避免全表扫描行锁状态。

mysql意向锁是做什么的_mysql锁协作机制说明

意向锁是用来避免全表扫描行锁状态的“预告灯”

当事务想对某几行加 S 锁(SELECT ... LOCK IN SHARE MODE)或 X 锁(SELECT ... FOR UPDATE)时,InnoDB 会**自动先在表级别加一个意向锁**:加行共享锁前加 IS 锁,加行排他锁前加 IX 锁。这不是你手动加的,也拦不住——它由引擎隐式维护,只为一个目的:让表级锁能快速判断“这表里有没有行正被锁着”

没有意向锁时,另一个事务想对整张表加 X 锁(比如 ALTER TABLE 或某些显式 LOCK TABLES ... WRITE),就得逐行检查是否被其他事务持有行锁——大表上这等于拒绝并发。

  • ISIX 本身互不冲突,可以并存(多个读/写事务可同时声明意图)
  • IS 与表级 X 锁冲突 → 表明“有人正在读部分行”,整表写必须等
  • IX 与表级 S 锁冲突 → 表明“有人正准备写部分行”,整表读也不安全
  • 全表扫描类操作(如没走索引的 UPDATE)可能触发 IX + 行锁升级,但意向锁本身从不阻塞任何操作——真正阻塞的是后续的表锁申请

什么时候你会“感知到”意向锁的存在

你不会直接看到 ISIX 出现在 SHOW ENGINE INNODB STATUS 的 LOCK WAIT 段里(它只显示最终阻塞链),但你能通过现象反推:

  • 执行 SELECT ... FOR UPDATE 后,另一个会话尝试 LOCK TABLES t1 WRITE 卡住 → 很可能是因为表上有未释放的 IX 锁(即前一个事务还没提交)
  • 事务 A 执行了 SELECT ... LOCK IN SHARE MODE,事务 B 紧接着执行 ALTER TABLE t1 ADD COLUMN c INT 被挂起 → 是因为 IS 锁和 DDL 需要的 X 表锁冲突
  • information_schema.INNODB_TRX 里查不到锁类型字段,但 INNODB_LOCK_WAITS 显示等待对象是表名而非行,基本就是意向锁引发的表级等待

常见误判:以为“没加表锁就没事”,其实意向锁早埋伏好了

很多开发者以为自己只操作单行、用了主键条件、没写 LOCK TABLES,就完全不涉及表级语义——错。只要用了悲观锁语法,意向锁就已生效:

Content at Scale
Content at Scale

SEO长内容自动化创作平台

下载
-- session-01
BEGIN;
SELECT * FROM users WHERE id = 100 FOR UPDATE;  -- 自动加 IX 锁(表级)+ X 锁(行级)
-- 此时 users 表已有 IX 锁,哪怕只锁了一行
-- session-02
BEGIN;
LOCK TABLES users WRITE;  -- 立即阻塞:IX 和表级 WRITE 不兼容
  • 即使你用的是唯一索引或主键,只要语句带 FOR UPDATELOCK IN SHARE MODE,意向锁就触发
  • INSERT 也会触发 IX 锁(尤其涉及自增列时,还叠加自增锁)
  • 显式 LOCK TABLES ... READ/WRITE 是用户层表锁,和意向锁分属不同机制,但会受其约束——这是最容易混淆的一点

调试和验证意向锁行为的实操建议

想确认意向锁是否在起作用?别猜,用这几招直接观察:

  • performance_schema.data_locks(MySQL 8.0+):过滤 LOCK_DATA IS NULL AND LOCK_MODE LIKE '%INTENTION%',能看到 IS/IX 记录
  • SHOW ENGINE INNODB STATUS\GTRANSACTIONS 段末尾的 lock struct(s),注意 table lock 类型且 lock_modeISIX
  • 测试时务必用两个以上会话,并保持事务未提交——意向锁生命周期=事务生命周期
  • 注意隔离级别影响:在 READ COMMITTED 下,某些非唯一条件查询可能不加间隙锁,但意向锁依然存在

最常被忽略的是:意向锁不是“可选优化”,而是 InnoDB 多粒度锁机制的基础设施。你绕不开它,但可以靠减少长事务、避免无索引扫描、控制悲观锁使用范围来降低它的副作用。

相关专题

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

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

658

2023.06.20

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

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

244

2023.06.21

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

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

280

2023.07.18

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

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

514

2023.07.19

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

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

253

2023.07.25

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

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

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

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

528

2023.08.11

mysql忘记密码
mysql忘记密码

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

597

2023.08.14

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

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

精品课程

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

共48课时 | 1.7万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 785人学习

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

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