面试官问:select......for update会锁表还是锁行?
1、支付宝员工因绩效3.25B被辞退,员工告上法院,结果来了! 2、Spring Boot + GraphQL 才是 API 的未来! 3、全员远程办公,半年入 1 亿美元:GitHub 的最大竞争对手上市了! 4、聊一聊Java 泛型通配符 T,E,K,V,? 5、各大公司程序员的工位,你中意哪一款?
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、《历史文章分类导读列表!精选优秀博文都在这里了!》 2、用 Java 爬小姐姐图片,这个厉害了。。。 3、消息幂等(去重)通用解决方案,真顶! 4、从MySQL 5.6升级到8.0,Facebook付出了惨痛代价…… 5、当 Transactional 碰到锁,有个大坑! 6、横空出世,比Visio快10倍的画图工具来了。 7、惊呆了,Spring中竟然有12种定义bean的方法 8、代码写的垃圾被嫌弃? 9、牛逼!SpringBoot+Vue企业级支付系统!附源码! 10、你真的会写for循环吗?来看看这些常见的for循环优化方式
评论