Java开发篇 - 库存超卖,库存扣成负数?

简介: 库存扣减的时机处理,有对与不对。

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

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

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

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

方案一 数据库字段控制

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

最后:方法比结论得,希望你能从中有收获。

目录
相关文章
|
7天前
|
IDE Java 开发工具
Spring Boot:加速Java后端开发的现代化利器
在当今快速迭代的软件开发环境中,Spring Boot 已成为Java后端开发领域的首选框架。作为Spring家族的一员,它以“约定优于配置”的设计理念,极大地简化了传统Spring应用的配置和部署过程,让开发者能够更加专注于业务逻辑的实现。本文将探讨Spring Boot的核心优势,并通过一个简单的示例展示如何快速启动一个基于Spring Boot的Java Web应用。
26 1
|
4天前
|
前端开发 Java 开发工具
Java GUI编程:跨平台应用的设计与开发
Java GUI编程:跨平台应用的设计与开发
|
3天前
|
存储 安全 Java
基于Java的区块链数字身份认证系统设计与开发
基于Java的区块链数字身份认证系统设计与开发
|
4天前
|
机器学习/深度学习 人工智能 Java
Java与AI集成开发:机器学习模型部署
Java与AI集成开发:机器学习模型部署
|
7天前
|
供应链 小程序 Java
基于Java超市库存管理系统设计和实现(源码+LW+调试文档+讲解等)
基于Java超市库存管理系统设计和实现(源码+LW+调试文档+讲解等)
|
9天前
|
Java easyexcel
java开发excel导入导出工具类基于EasyExcel
java开发excel导入导出工具类基于EasyExcel
19 1
|
1天前
|
开发框架 Java API
Java中的REST API开发详解
Java中的REST API开发详解
|
1天前
|
自然语言处理 Java
Java中的行为驱动开发(BDD)实践
Java中的行为驱动开发(BDD)实践
|
2天前
|
监控 Java 开发者
使用Java开发微服务架构的挑战与解决方案
使用Java开发微服务架构的挑战与解决方案
|
2天前
|
前端开发 Java 开发工具
Java GUI编程:跨平台应用的设计与开发
Java GUI编程:跨平台应用的设计与开发