select …….for update加的是行锁还是表锁?

2023-11-0710:38:38数据库教程Comments1,342 views字数 818阅读模式

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select查询语句是不会加锁的,但是select ....for update除外。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

问题:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select .......for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

带着问题我们继续往下看。

验证:

建表sql文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

CREATE TABLE `atao` (`id` INT ( 11 ) NOT NULL AUTO_INCREMENT,`name` VARCHAR ( 255 ) DEFAULT NULL, `age` INT ( 11 ) DEFAULT NULL, PRIMARY KEY ( `id` ),KEY `idx_age` ( `age` ) USING BTREE ) ENGINE = INNODB;
insert into atao(name,age) values ('唐三藏','20');insert into atao(name,age) values ('孙悟空','500');insert into atao(name,age) values ('猪八戒','100');insert into atao(name,age) values ('沙悟净','50');

关闭自动提交:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

案例一(主键):文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

开启第一个事务:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

第二个事务去更新数据,被阻塞了,长时间拿不到锁报错。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

我们再开启一个事务对另一条id为2的数据进行更新,更新成功。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

案例二 (索引):文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

age创建了唯一索引。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

开启第一个事务:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

第二个事务去更新数据,被阻塞了,长时间拿不到锁报错。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

我们再开启一个事务对另一条id为2的数据进行更新,更新成功。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

案例三 (普通字段):文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

使用普通的字段name去操作,开启第一个事务。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

第二个事务去更新数据,被阻塞了,长时间拿不到锁报错。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

我们再开启一个事务对另一条id为2的数据进行更新,如果我更新成功了,就是锁行,失败了就是锁表。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

select …….for update加的是行锁还是表锁?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

结论:

如果查询条件用了索引/主键,那么select ... for update就会进行行锁。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

如果是普通字段(没有索引/主键),那么select ... for update就会进行锁表。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

来源:数据与人文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/56755.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/sjk/56755.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定