建网站教学,wap网站登陆系统,青海网站开发公司,公司的网站哪个部门做select for update含义
select查询语句是不会加锁的#xff0c;但是 select for update除了有查询的作用外#xff0c;还会加锁呢#xff0c;而且它是悲观锁哦。至于加了是行锁还是表锁#xff0c;这就要看是不是用了索引/主键啦。
没用索引/主键的话就是表锁#xff0c…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 ) ENGINEInnoDB AUTO_INCREMENT1570068 DEFAULT CHARSETutf8 id为主键select for update 1270070这条记录时再开一个事务对该记录更新发现更新阻塞啦其实是加锁了。如下图 我们再开一个事务对另外一条记录 1270071更新发现更新成功因此如 果查询条件用了索引/主键会加行锁~ 我们继续换普通字段 balance吧发现又阻塞了。因此没用索引/主键的话selectfor update加的就是表锁