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

相关推荐
h***04771 小时前
SpringBoot(7)-Swagger
java·spring boot·后端
v***91303 小时前
Spring boot创建时常用的依赖
java·spring boot·后端
5***E6855 小时前
【SQL】写SQL查询时,常用到的日期函数
数据库·sql
代码or搬砖6 小时前
MyBatisPlus讲解(二)
java·mybatis
遇见火星6 小时前
CentOS7 通过源码安装 Redis
数据库·redis·缓存
lcu1116 小时前
Java 学习42:抽象
java
Mr.朱鹏6 小时前
RocketMQ安装与部署指南
java·数据库·spring·oracle·maven·rocketmq·seata
雨中飘荡的记忆6 小时前
Spring表达式详解:SpEL从入门到实战
java·spring
Coder-coco6 小时前
个人健康管理|基于springboot+vue+个人健康管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·mysql·论文
K哥11256 小时前
【9天Redis系列】基础+全局命令
数据库·redis·缓存