乐观锁解决并发问题

业务场景

一般的商城业务中,我们经常会遇到一种场景,某商品库存只剩最后一件,但此时有多个用户同时下单,如果没有做任何的处理,多个用户下单时进程读取到的库存为1,程序判断符合扣库存条件,下单成功,就会造成库存变成负数的情况

解决方案

思路

乐观锁通过增加一个每次更新库存都会自增的version字段来解决这个问题,每个进程读取库存字段的同时,也会读取version的值,在更新库存同时更新version,并增加对version字段值的判断

代码实现
<!-- 乐观锁更新库存 -->
<update id="newMinStock" parameterType="java.util.Map">
    update goods
    set stock= stock - 1,version = #{version} + 1
    where id  = #{id} and version = #{version}
</update>

假设有两个进程都读取到了stock的值为1,version默认值为0,则这两个进程执行的更新语句都是update goods set stock=stock-1,version=version+1 where id=1 and version=0,当其中一个进程执行成功之后,数据库中version的值就会变为1,剩下的进程不会执行成功,这样保证了stock的值不会小于0

Map<String, Object> map = new HashMap<>();
map.put("id", id);
map.put("version", version);
int result = goodsMapper.newMinStock(map);

if (result != 1) {
    throw new RuntimeException("更新商品库存失败");
}

在业务层判断更新库存是否成功,进行相应的业务处理

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 引言为什么需要锁(并发控制)?在多用户环境中,在同一时间可能会有多个用户更新相同的记录,这会产生冲突。这就是著名的...
    刀刃丿阅读 4,010评论 0 0
  • 重复添加购物车 背景 购物车中同一商品只能有一条记录添加购物车时,如果商品已经存在,则在原来的数量上增加;如果不存...
    齐晋阅读 7,261评论 4 11
  • 本质: 悲观锁和乐观锁都是一种概念和认知。数据库有java语言都有对应的实现方式。 悲观锁 悲观锁(Pessimi...
    极简架构阅读 4,221评论 0 3
  • 一、事务 1、事务四要素:ACID 对于事务,我之前的理解是很粗糙的,不就是为了保证操作的原子性么?一般订单系统或...
    张伟科阅读 5,160评论 0 5
  • Milestone 本文需要阅读时间大约在1小时,请抽出完整的时间来阅读,一目十行,真心没用 后面会按照下图,分批...
    你好Max阅读 39,070评论 53 132