面试官问:select......for update会锁表还是锁行?
好好学java
共 1260字,需浏览 3分钟
·
2021-11-06 22:21
今日推荐 扔掉 Postman,一个工具全部搞定,真香! 为啥查询那么慢? 还在直接用JWT做鉴权?JJWT真香 推荐 15 款常用开发工具 干掉 navicat:这款 DB 管理工具才是y(永)y(远)d(的)s(神)
select .......for update
除了有查询的作用外,还会加锁呢,而且它是悲观锁。验证:
//id为主键
//name 为唯一索引
CREATE TABLE `user` (
`id` INT ( 11 ) NOT NULL AUTO_INCREMENT,
`name` VARCHAR ( 255 ) DEFAULT NULL,
`age` INT ( 11 ) DEFAULT NULL,
`code` VARCHAR ( 255 ) DEFAULT NULL,
PRIMARY KEY ( `id` ),
KEY `idx_age` ( `age` ) USING BTREE
) ENGINE = INNODB AUTO_INCREMENT = 1570068 DEFAULT CHARSET = utf8
set @@autocommit=0;
设置为手动提交。0代表手动提交,1代表自动提交。结合一下实例验证
图一为第一个事务,并且没有提交事务 图二为第二个事务,去更新数据,被阻塞了 图三为第二个事务,长时间拿不到锁报错。
结果:
select ..... for update
就会进行行锁。select ..... for update
就会进行锁表。感谢阅读,希望对你有所帮助 :) 来源:blog.csdn.net/qq_42956376/article/details/109544539
推荐文章
1、一款高颜值的 SpringBoot+JPA 博客项目 2、超优 Vue+Element+Spring 中后端解决方案 3、推荐几个支付项目! 4、推荐一个 Java 企业信息化系统 5、一款基于 Spring Boot 的现代化社区(论坛/问答/社交网络/博客)
评论