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

相关推荐
电魂泡哥6 分钟前
CMS垃圾回收
java·jvm·算法
Amctwd24 分钟前
【Python】从Excel中按行提取图片
java·python·excel
环流_27 分钟前
Redis中string类型的应用场景
数据库·redis·缓存
倔强的石头_27 分钟前
拒绝被复杂报表拖垮!HTAP场景下“标量子查询消除”硬核调优指南
数据库
啃臭33 分钟前
AOP和反射
java·spring boot
环流_38 分钟前
redis中list类型
数据库·redis·list
西凉的悲伤41 分钟前
java 使用PNG图片隐写文件
java·图片隐写·png
有梦想的小何43 分钟前
Cursor AI 编程实战(篇一):Prompt 与案例总结
java·linux·prompt·ai编程
河阿里1 小时前
SpringBoot:Spring Task定时任务完整使用教学
java·spring boot·spring
jiayong231 小时前
Tool Permission 与 Sandbox 的安全流水线:Agent 工具系统的工程边界
java·数据库·安全·agent