mysql表锁、行锁、索引之间暧昧的关系
程序员文章站
2022-03-17 11:48:26
MySQL的innodb存储引擎支持行级锁,innodb的行锁是通过给索引项加锁实现的,这就意味着只有通过索引条件检索数据时,innodb才使用行锁,否则使用表锁。根据当前的数据更新语句(UPDATE user set name='11111' where account='1'),该条件字段acc ......
mysql的innodb存储引擎支持行级锁,innodb的行锁是通过给索引项加锁实现的,这就意味着只有通过索引条件检索数据时,innodb才使用行锁,否则使用表锁。
根据当前的数据更新语句(update user set name='11111' where account='1'),该条件字段account并没有添加索引,所以导致数据表被锁。
我们验证一下:
第一种情况,通过非索引条件检索数据时,使用的是表锁,会导致数据表被锁
1.首先,我们将mysql事务设置为不自动提交,mysql事务默认是自动提交事务的,1表示自动提交事务
mysql> select @@autocommit; +--------------+ | @@autocommit | +--------------+ | 1 | +--------------+ 1 row in set
mysql> set autocommit = 0 ; query ok, 0 rows affected
2.起一个命令行,开始事务,更新第一条记录,先不提交
mysql> start transaction; query ok, 0 rows affected mysql> beg in; query ok, 0 rows affected mysql> update user set name='11111' where account='1' ->
3.我们再起一个命令行,更新第二条记录
update user set name='2222' where id='2'
4.看下表的数据
可以看到,数据表没有更新
5.把第一个命令行的事务提交了
mysql> commit; query ok, 0 rows affected
我们看到现在数据更新了。
第二种情况,通过索引条件检索数据时,使用的是行锁
如第一种情况,自己测试下。
上一篇: 今天三男一女来买结婚穿的衣服
下一篇: 好酒
推荐阅读