开发小技巧系列 - 库存超卖,库存扣成负数?

开发小技巧系列文章,是本人对过往平台系统的设计开发及踩坑的记录与总结,给初入平台系统开发的开发人员提供参考与帮助。

库存超卖,库存扣成负数,这是初入电商平台下单业务时就会遇到的坑。电商平台顾名思义就是买卖双方进行商品交易的平台,买家购买商品后,卖家的商品的总库存要进行扣减,卖家才能知道商品的实际库存(存货与售卖情况),如果不扣减,就不能知道商品销售及库存情况,也就无法进行补货,发货等需要。

一般比较常见的扣减库存的方式有:下单扣减库存,付款扣减库存,预扣库存。至于选择那种扣减的方式,要由具体的业务来定,但前提是在并发的情况下,要保证库存的准确性,不能出现负数(超卖)。

那么在更新数据库表的库存值时,有什么解决方案?

方案一

在设计数据表的库存字段时,数据类型设置为“无符号整数”,这样在执行SQL语句更新库存字段时,SQL语会报错,控制字段值不为负数。

方案二

在更新库存的SQL语句上,加上库减后的库存值必须大于等于0, 这种也可以有效防止超卖的场景。如:

    update stock set cur_stock = cur_stock-#{qty} where id=#{id} and cur_stock-#{qty}>=0;

    注意:在过往的工作中,经常有发现开发同事,将库存的值读出来,在程序里面进行加减后,在更新回数据库,这种是不行的,操作不具有原子性。如下的逻辑是错误:

      Stock curStock = stockService.get(xx);
      if(curStock-qty<0){  
        //抛出超卖的异常
      }
      stock.setCurStock(curStock - qty);
      stockService.update(curStock);

      后续还会其他系统文件跟上。

      更多内容交流,可以查看技术老男孩 公众号

      腾讯云推出云产品限时特惠抢购活动:2C2G云服务器7.9元/月起
      本文链接:https://www.jhelp.net/p/kXAonppbu4qkbNIV (转载请保留)。
      关注下面的标签,发现更多相似文章