From 9bcc40d213a44498c46dae5e678e592b918b40b0 Mon Sep 17 00:00:00 2001 From: rentaiming <806181062@qq.com> Date: 星期四, 30 五月 2024 18:33:54 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSkuServiceImpl.java | 65 +++++++++++++++++++++----------- 1 files changed, 43 insertions(+), 22 deletions(-) diff --git a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSkuServiceImpl.java b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSkuServiceImpl.java index 6965243..5427e04 100644 --- a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSkuServiceImpl.java +++ b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSkuServiceImpl.java @@ -24,11 +24,15 @@ import com.ruoyi.goods.service.IGoodsSkuService; import com.ruoyi.system.api.domain.GoodsSeckill; import com.ruoyi.system.api.domain.GoodsSku; +import com.ruoyi.system.api.domain.dto.GoodsStockUpdDTO; import com.ruoyi.system.api.domain.dto.ListStatusDTO; import java.util.List; +import java.util.Map; import java.util.Objects; +import java.util.stream.Collectors; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; +import org.redisson.api.RedissonClient; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; @@ -49,6 +53,8 @@ private final IGoodsInfoTitleValueService goodsInfoTitleValueService; private final IGoodsSeckillService goodsSeckillService; private final IGoodsGroupPurchaseService goodsGroupPurchaseService; + private final RedissonClient redissonClient; + private static final ObjectMapper objectMapper = new ObjectMapper(); /** @@ -203,37 +209,52 @@ .list(); } + /** - * 扣减商品库存 + * 批量更新商品库存 auctionStock 负数则为减库存,正数为加库存 * - * @param goodsSkuId 商品SKU ID - * @param auctionStock 拍卖库存 + * @param goodsStockUpdDTOS 商品库存修改数据传输对象 */ @Override - public void deductStock(Long goodsSkuId, Integer auctionStock) { - GoodsSku goodsSku = this.getById(goodsSkuId); - if (StringUtils.isNull(goodsSku)) { + @Transactional(propagation = Propagation.REQUIRES_NEW) + public void returningStock(List<GoodsStockUpdDTO> goodsStockUpdDTOS) { + List<Long> goodsSkuIdList = goodsStockUpdDTOS.stream() + .map(GoodsStockUpdDTO::getGoodsSkuId) + .collect(Collectors.toList()); + List<GoodsSku> goodsSkus = this.listByIds(goodsSkuIdList); + + if (StringUtils.isEmpty(goodsSkus)) { throw new ServiceException("商品不存在"); } - if (goodsSku.getStock() < auctionStock) { - throw new ServiceException("库存不足"); + Map<Long, Integer> stockMap = goodsStockUpdDTOS.stream() + .collect(Collectors.toMap(GoodsStockUpdDTO::getGoodsSkuId, + GoodsStockUpdDTO::getAuctionStock)); + for (GoodsSku skus : goodsSkus) { + Integer auctionStock = stockMap.get(skus.getId()); + if (StringUtils.isNotNull(auctionStock) && auctionStock > 0) { + // 更新商品库存,更新五次失败抛出异常 + boolean isUpdated = false; + for (int i = 0; i < 5; i++) { + isUpdated = updateGoodsStock(skus, auctionStock); + if (isUpdated) { + break; + } else { + skus = this.getById(skus.getId()); + } + } + if (!isUpdated) { + throw new ServiceException("商品库存回退失败"); + } + } } - // 更新商品库存 - this.lambdaUpdate().set(GoodsSku::getStock, goodsSku.getStock() - auctionStock) - .ge(GoodsSku::getStock, auctionStock).eq(GoodsSku::getId, goodsSku.getId()) - .update(); + } - @Override - public void returningStock(Long goodsSkuId, Integer auctionStock) { - GoodsSku goodsSku = this.getById(goodsSkuId); - if (StringUtils.isNull(goodsSku)) { - throw new ServiceException("商品不存在"); - } - // 更新商品库存 - this.lambdaUpdate() - .set(auctionStock > 0, GoodsSku::getStock, goodsSku.getStock() + auctionStock) - .eq(GoodsSku::getId, goodsSku.getId()) + private boolean updateGoodsStock(GoodsSku skus, Integer auctionStock) { + return this.lambdaUpdate() + .set(GoodsSku::getStock, skus.getStock() + auctionStock) + .eq(GoodsSku::getId, skus.getId()) + .eq(GoodsSku::getStock, skus.getStock()) .update(); } } -- Gitblit v1.7.1