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

相关推荐
恣艺3 分钟前
Redis有序集合(ZSet):排行榜功能的最优解,原理与实战
数据库·chrome·redis
2501_926227943 分钟前
UDP网络编程:【Java】无连接通信到Socket实战(二)
java·网络·udp
Sunny_yiyi16 分钟前
Java根据模版导出PDF文件
java·开发语言·pdf
麦兜*17 分钟前
MongoDB 与 GraphQL 结合:现代 API 开发新范式
java·数据库·spring boot·mongodb·spring·maven·graphql
shan&cen20 分钟前
Day02 集合 | 30. 串联所有单词的子串、146. LRU 缓存、811. 子域名访问计数
java·数据结构·算法·缓存
ITMan彪叔39 分钟前
Java MQTT 主流开发方案对比
java·后端
召摇1 小时前
Java 21到25的核心API演进总结
java·后端
知其然亦知其所以然1 小时前
SpringAI 玩转 OCI GenAI:这次我们聊聊 Cohere 聊天模型
java·后端·spring
亭台烟雨中1 小时前
SQL优化简单思路
数据库·sql