开发小技巧系列文章,是本人对过往平台系统的设计开发及踩坑的记录与总结,给初入平台系统开发的开发人员提供参考与帮助。
库存超卖,库存扣成负数,这是初入电商平台下单业务时就会遇到的坑。电商平台顾名思义就是买卖双方进行商品交易的平台,买家购买商品后,卖家的商品的总库存要进行扣减,卖家才能知道商品的实际库存(存货与售卖情况),如果不扣减,就不能知道商品销售及库存情况,也就无法进行补货,发货等需要。
一般比较常见的扣减库存的方式有:下单扣减库存,付款扣减库存,预扣库存。至于选择那种扣减的方式,要由具体的业务来定,但前提是在并发的情况下,要保证库存的准确性,不能出现负数(超卖)。
那么在更新数据库表的库存值时,有什么解决方案?
方案一 数据库字段控制
在设计数据表的库存字段时,数据类型设置为“无符号整数”,这样在执行SQL语句更新库存字段时,SQL语会报错,控制字段值不为负数。
方案二 sql更新判断
在更新库存的SQL语句上,加上库减后的库存值必须大于等于0, 这种也可以有效防止超卖的场景。如:
ini复制代码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);