MySQL中悲观锁和乐观区别

本文对比了MySQL中的悲观锁和乐观锁。悲观锁在整个数据处理过程中保持锁定,适合写操作频繁的场景;而乐观锁在更新数据时才加锁,适用于读操作多的情况。常见实现包括版本号机制,适用于读多写少的环境,减少并发冲突。
摘要由CSDN通过智能技术生成

1、概念不同

乐观锁( Optimistic Locking):

顾名思义,对加锁持有一种乐观的态度,即先进行业务操作,不到最后一步不进行加锁,"乐观"的认为加锁一定会成功的,在最后一步更新数据的时候再进行加锁。

悲观锁(Pessimistic Lock):

正如其名字一样,悲观锁对数据加锁持有一种悲观的态度。因此,在整个数据处理过程中,将数据处于锁定状态。悲观锁的实现,往往依靠数据库提供的锁机制(也只有数据库层提供的锁机制才能真正保证数据访问的排他性,否则,即使在本系统中实现了加锁机制,也无法保证外部系统不会修改数据)。

2、实现方式不同

乐观锁:

version方式:一般是在数据表中加上一个数据版本号version字段,表示数据被修改的次数,当数据被修改时,version值会加一。当线程A要更新数据值时,在读取数据的同时也会读取version值,在提交更新时,若刚才读取到的version值为当前数据库中的version值相等时才更新,否则重试更新操作,直到更新成功。

(换一种说法:小明去银行取钱,取钱的时候系统读表,也会读取表中 version 字段,读取的时候是 1,操作完成后 version 字段会加一,变成 2,但是在他操作提交之前,小红也用这个账号取钱,读取到 ver

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值