Mysql 中 select ... for update 加锁总结

新建一张表

复制代码
CREATE TABLE `stu` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  `code` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `idx_age` (`age`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=1570068 DEFAULT CHARSET=utf8;

id 为主键, name和code为普通字段, age为索引字段.

插入两条测试数据如下:

(1) 以主键字段作为条件上锁

开启事物A 以id字段作为条件上锁, 操作如下

事务B执行更新 1001这条记录

操作超时更新失败.

而更新 1009 这条记录成功.

说明 以主键字段作为条件上锁,锁的是行,是表中查询命中的数据.

(2) 以索引字段作为条件上锁

开启事物A 以 age 字段作为条件上锁, 操作如下

事务B执行更新 1001这条记录

操作超时报错.

更新 1009 这条记录, 更新成功

说明和(1)一样, 以索引字段作为条件上锁, 锁住的是行, 是表中查询命中的数据.

(3) 以普通字段作为条件上锁

开启事物A, 以name字段为条件加锁

事物B更新 1001这条记录, 超时失败

再更新 1009 这条, 也是超时失败

说明, 以普通字段作为条件上锁, 锁的是表, 是表中的所有数据.

以下是三种情况的总结:

(1) 以主键字段作为条件上锁,锁的是行,是表中查询命中的数据

(2) 以索引字段作为条件上锁,锁的是行,是表中查询命中的数据

(3) 以普通字段作为条件上锁, 锁的是该表, 是表中的所有数据


and 和 or 组合条件

说明:

显示sql更新操作超时时间以及如何修改

在Navicat 中可以执行

show VARIABLES like 'innodb_lock_wait_timeout'; 显示更新操作超时时间

set innodb_lock_wait_timeout = 10; 可以修改超时时间, 单位是秒. 但是但是注意这种临时修改的方法只会在当前会话(也就是Navicat的一个查询) 中生效.

相关推荐
曹轲恒6 分钟前
SpringBoot配置文件(1)
java·spring boot·后端
风叶悠然6 分钟前
vue3中数据的pinia的使用
前端·javascript·数据库
a努力。8 分钟前
中国电网Java面试被问:RPC序列化的协议升级和向后兼容
java·开发语言·elasticsearch·面试·职场和发展·rpc·jenkins
毕设源码-钟学长11 分钟前
【开题答辩全过程】以 基于SSM框架的月子中心管理系统的设计与实现为例,包含答辩的问题和答案
java
码农水水15 分钟前
得物Java面试被问:大规模数据的分布式排序和聚合
java·开发语言·spring boot·分布式·面试·php·wpf
Chan1620 分钟前
【 微服务SpringCloud | 模块拆分 】
java·数据结构·spring boot·微服务·云原生·架构·intellij-idea
独断万古他化21 分钟前
【二分算法 深度解析】二段性思维与经典题型全通关
java·算法
摇滚侠22 分钟前
尚硅谷 Nginx 教程(亿级流量 Nginx 架构设计),基本使用,笔记 6-42
java·笔记·nginx
JosieBook25 分钟前
【数据库】2026国产时序数据库新格局与金仓的多模突围
数据库·时序数据库
SenChien26 分钟前
Java大模型应用开发day06-天机ai-学习笔记
java·spring boot·笔记·学习·大模型应用开发·springai