select for update会锁表还是行锁还是其它

select for update含义

select查询语句是不会加锁的,但是 select for update除了有查询的作用外,还会加锁呢,而且它是悲观锁哦。至于加了是行锁还是表锁,这就要看是不是用了索引/主键啦。

没用索引/主键的话就是表锁,否则就是是行锁。

select for update加锁验证

表结构:

//id为主键,name为唯一索引

CREATE TABLE account (
id int(11) NOT NULL AUTO_INCREMENT,
name varchar(255) DEFAULT NULL,
balance int(11) DEFAULT NULL,

PRIMARY KEY (id),

KEY idx_name (name) USING BTREE

) ENGINE=InnoDB AUTO_INCREMENT=1570068 DEFAULT CHARSET=utf8

id为主键,select for update 1270070这条记录时,再开一个事务对该记录更新,发现更新阻塞啦,其实是加锁了。如下图:

我们再开一个事务对另外一条记录 1270071更新,发现更新成功,因此,如

果查询条件用了索引/主键,会加行锁~

我们继续,换普通字段 balance吧,发现又阻塞了。因此,没用索引/主键的话,selectfor update加的就是表锁

相关推荐
失散13几秒前
分布式专题——41 RocketMQ集群高级特性
java·分布式·架构·rocketmq
失散133 分钟前
分布式专题——42 MQ常见问题梳理
java·分布式·架构
四维碎片4 分钟前
【Qt】乌班图安装Qt环境
开发语言·数据库·qt
wuyunhang12345613 分钟前
MySQL----触发器
数据库·mysql
爱编程的鱼26 分钟前
C# 变量详解:从基础概念到高级应用
java·算法·c#
ptc学习者27 分钟前
OGG 安装注意事项
java·开发语言·数据库
Camel卡蒙30 分钟前
DDD架构——充血模型、领域模型
java·设计模式·架构
n8n42 分钟前
RabbitMQ全面详解:从核心概念到企业级应用
java·rocketmq
用户7851278147044 分钟前
实战代码:获取淘宝商品详情数据接口
java
Chan161 小时前
流量安全优化:基于 Sentinel 实现网站流量控制和熔断
java·spring boot·安全·sentinel·intellij-idea·进程