【DB锁】数据库中-乐观锁与悲观锁

本文深入探讨了乐观锁和悲观锁的区别。悲观锁适用于冲突频繁的场景,而乐观锁则通常在冲突较少时使用。通过在提交前进行select for update检查的策略,可以视为悲观锁的一种变种。在实践中,采用带有更新前状态的更新语句,如检查订单状态的更新操作,可以确保数据的一致性。
摘要由CSDN通过智能技术生成


乐观锁和悲观锁的区别(最全面的分析)

         悲观锁(Pessimistic Lock),  顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁。它指的是对数据被外界(包括本系统当前的其他事务,以及来自外部系统的事务处理)修改持保守态度,因此,在整个数据处理过程中,将数据处于锁定状态。悲观锁的实现,往往依靠数据库提供的锁机制(也只有数据库层提供的锁机制才能真正保证数据访问的排他性,否则,即使在本系统中实现了加锁机制,也无法保证外部系统不会修改数据)。

          乐观锁(Optimistic Lock),  顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改ÿ
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值