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加的就是表锁

相关推荐
jeffer_liu14 分钟前
Spring AI 生产级实战:裁判员
java·人工智能·后端·spring·大模型
小bo波1 小时前
枚举实战
java·设计模式·枚举·后端开发·代码重构
_1_71 小时前
SQL Server 磁盘满了 收缩日志
数据库·sqlserver
夜微凉41 小时前
三、Spring
java·后端·spring
basketball6161 小时前
Redis基础:1. Redis介绍
数据库·redis·缓存
橘右今2 小时前
2026 Java后端高频面试宝典
java·开发语言·面试
李可以量化2 小时前
成交量的终极量化策略:价量共振指标完整实现(下篇)
前端·数据库·人工智能
xyzzklk3 小时前
解决Salesforce无法向外发送邮件
android·java·开发语言·网络·crm·salesforce·客户关系管理
biubiubiu07063 小时前
SpringBoot关于外部化配置
java·spring boot·spring
zzz_23683 小时前
【Spring】面试突击系列(二):SpringBoot 入门与自动配置原理
java·spring boot·spring