mysql行锁是加在索引_mysql表锁、行锁、索引之间暧昧的关系

本文探讨了MySQL中InnoDB存储引擎的行级锁特性,指出行锁仅在通过索引条件检索数据时生效。通过一个例子展示了当更新条件字段未建立索引时,数据表会使用表锁而非行锁,导致全表锁定。实验过程包括设置事务不自动提交,执行更新操作,然后尝试另一事务更新不同记录,最后提交事务观察结果。结论强调了索引对于行锁的重要性。
摘要由CSDN通过智能技术生成

2c8f2497ede3d135a510317ab6f724ee.png

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.看下表的数据

534f5e51222a8c415404fc96211f8745.png

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

mysql

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

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

mysql> commit;

Query OK, 0 rows affected

778ef6421254d53327b33a64c97e1401.png

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

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值