mysql实现乐观锁与悲观锁

  • 乐观锁:
    认为当前竞争度不高的情况使用,类似于java中的cas操作,一般是在表的字段中设置版本号,代码中先获取记录及对应的版本号,然后执行逻辑操作,最后循环进行,update … version=version_+1 and… where version=verson_ …直到成功。
  • 悲观锁:
    认为当前竞争度高的情况使用,一般是,一锁二查(2.5 逻辑操作)三更新。可以用select… for update实现。

并发度高的情况下用乐观锁会频繁更新失败得不偿失,并发读低的情况下用乐观锁只在update时上锁,一来可以提高并发性能,二来锁的重量级应该较轻。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值