Java商品库存管理需面向对象建模,定义含ID/名称/单价的Product类和含数量/预警阈值/版本号的Inventory类,封装增减查校验方法,通过乐观锁、数据库WHERE条件或Redis+Lua保障并发安全,并用JDBC/MyBatis持久化。

Java版商品库存管理的核心是用面向对象方式建模商品与库存行为,结合数据持久化和线程安全控制,确保增减库存准确、并发安全、状态可追溯。
定义商品与库存实体类
先设计清晰的数据结构。商品(Product)应包含ID、名称、单价等基本信息;库存(Inventory)则需记录商品ID、当前数量、预警阈值、最后更新时间等。建议用Lombok简化getter/setter,用final修饰不可变字段:
- Product类用Long id、String name、BigDecimal price,避免基本类型空值风险
- Inventory类聚合Product,用int quantity(或AtomicInteger支持原子操作),加上version字段用于乐观锁
- 重写equals/hashCode,方便后续集合操作与缓存比对
实现库存核心业务逻辑
关键操作包括入库(increase)、出库(decrease)、查询(getQuantity)和校验(checkAvailability)。不直接暴露quantity字段,全部走方法封装:
- decrease()方法内先判断quantity >= required,不足则抛自定义异常(如InsufficientStockException)
- increase()支持批量入库,同时更新lastUpdated时间戳
- 所有变更操作返回Inventory对象或boolean结果,便于链式调用或日志记录
保障并发安全与数据一致性
高并发下单场景下,多个线程同时扣减同一商品库存极易超卖。推荐分层处理:
立即学习“Java免费学习笔记(深入)”;
- 应用层:用synchronized(this)或ReentrantLock做方法级互斥(适合单JVM)
- 数据库层:UPDATE inventory SET quantity = quantity - ? WHERE id = ? AND quantity >= ?,依赖WHERE条件+影响行数判断是否执行成功
- 进阶方案:Redis + Lua脚本实现原子扣减,再异步落库,兼顾性能与最终一致性
接入持久化与简单管理接口
用JDBC Template或MyBatis操作MySQL,InventoryMapper接口提供selectById、updateWithVersion等方法。对外暴露InventoryService:
- addStock(Long productId, int amount) —— 入库并校验正数
- deductStock(Long productId, int amount) —— 扣减前查+扣减后写,含事务注解@Transactional
- getStockStatus(Long productId) —— 返回DTO含商品信息、剩余量、是否低于预警
基本上就这些。不需要复杂框架也能跑通核心流程,重点是把库存变更的边界条件(负数、超限、并发)在代码里写实、写严。










