记录下for update 和 lock in share mode的区别

本文详细探讨了MySQL中for update(排他锁)和lock in share mode(共享锁)的区别。在共享锁下,事务可以读取但不能修改数据,而排他锁允许读取和修改。加锁事务与其他事务的交互场景被逐一分析,揭示了行锁在有无索引情况下的行为差异。通过实例展示了事务操作步骤,强调了索引对于行锁的重要性和全表扫描的可能性。
摘要由CSDN通过智能技术生成

 

  • lock in share mode 就是共享锁

如果事务对某行数据加上共享锁之后,可进行读写操作;其他事务可以对该数据加共享锁,但不能加排他锁,且只能读数据,不能修改数据。 某个事物想进行修改数据操作,那他必须等其他事物的共享锁都释放完毕才能进行修改操作

  • for update 排他锁,就是行锁

如果事务对数据加上排他锁之后,则其他事务不能对该数据加任何的锁。获取排他锁的事务既能读取数据,也能修改数据。

注:普通 select 语句默认不加锁,而CUD操作默认加排他锁。

 

例子:

下面例子的前提都是针对同一行数据。

1.同一行数据为前提,两个事物都进行共享锁查询

2.同一行数据为前提,一个事物进行共享锁查询,另一个事物进行修改

第一个占有着共享锁,第二个事物没法更新,必须等第一个事物释放才能进行更新

3.同一行数据为前提,一个进行共享锁查询,另一个先进行共享锁查询,然后update

同第二种,修改的事物就一直在转圈圈,等待事物1提交。事物1不提交,那事物2只能等到超时返回错误。

4.同一行数据为前提,当事物一获得共享锁,另一个事物是否可以获得排它锁

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值