mysql表锁行锁索引之间暧昧的关系

Posted 撸码识途

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql表锁行锁索引之间暧昧的关系相关的知识,希望对你有一定的参考价值。

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

我们看到现在数据更新了。

 

第二种情况,通过索引条件检索数据时,使用的是行锁

如第一种情况,自己测试下。

 


以上是关于mysql表锁行锁索引之间暧昧的关系的主要内容,如果未能解决你的问题,请参考以下文章

MySQL-加锁规则(间隙锁临键锁行锁表锁)

MySQL-加锁规则(间隙锁临键锁行锁表锁)

Mysql表锁行锁页锁

MySQL ---- 共享锁独占锁行锁表锁

MySQL ---- 共享锁独占锁行锁表锁

mysql数据库表锁行锁