码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2018-11-12 20:26:53      阅读:213      评论:0      收藏:0      [点我收藏+]

标签:proc   存储   命令行   被锁   第一条   ado   通过   comm   验证   

技术分享图片
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.看下表的数据
技术分享图片
mysql表锁、行锁、索引之间暧昧的关系
mysql

可以看到,数据表没有更新

5.把第一个命令行的事务提交了


mysql> commit;
Query OK, 0 rows affected

技术分享图片

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

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

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

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

标签:proc   存储   命令行   被锁   第一条   ado   通过   comm   验证   

原文地址:http://blog.51cto.com/13981400/2316039

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!