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的一个查询) 中生效.

相关推荐
小陈工2 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
0xDevNull6 小时前
MySQL数据冷热分离详解
后端·mysql
一定要AK6 小时前
Spring 入门核心笔记
java·笔记·spring
A__tao6 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
KevinCyao6 小时前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
科技小花6 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸6 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain6 小时前
linux个人心得22 (mysql)
数据库·mysql
迷藏4946 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
阿里小阿希7 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql