开发小技巧系列文章,是本人对过往平台系统的设计开发及踩坑的记录与总结,给初入平台系统开发的开发人员提供参考与帮助。
库存超卖,库存扣成负数,这是初入电商平台下单业务时就会遇到的坑。电商平台顾名思义就是买卖双方进行商品交易的平台,买家购买商品后,卖家的商品的总库存要进行扣减,卖家才能知道商品的实际库存(存货与售卖情况),如果不扣减,就不能知道商品销售及库存情况,也就无法进行补货,发货等需要。
一般比较常见的扣减库存的方式有:下单扣减库存,付款扣减库存,预扣库存。至于选择那种扣减的方式,要由具体的业务来定,但前提是在并发的情况下,要保证库存的准确性,不能出现负数(超卖)。
那么在更新数据库表的库存值时,有什么解决方案?
方案一
在设计数据表的库存字段时,数据类型设置为“无符号整数”,这样在执行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);
后续还会其他系统文件跟上。
更多内容交流,可以查看技术老男孩 公众号
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
本文链接:https://www.jhelp.net/p/kXAonppbu4qkbNIV (转载请保留)。