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

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

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

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

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

方案一

在设计数据表的库存字段时,数据类型设置为“无符号整数”,这样在执行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);

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

更多内容,欢迎关注本人微信

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值