From d02285e2e8c4d5127a62acb9c8285e6f7c6128d0 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Mon, 28 Jun 2021 17:19:29 +0800 Subject: [PATCH] 20210628 商品分类 --- gc-shop/src/main/java/com/xzx/gc/shop/service/OrderService.java | 41 ++++++++++++++++++++++++++++++++++++++++- 1 files changed, 40 insertions(+), 1 deletions(-) diff --git a/gc-shop/src/main/java/com/xzx/gc/shop/service/OrderService.java b/gc-shop/src/main/java/com/xzx/gc/shop/service/OrderService.java index 606efc2..022caf0 100644 --- a/gc-shop/src/main/java/com/xzx/gc/shop/service/OrderService.java +++ b/gc-shop/src/main/java/com/xzx/gc/shop/service/OrderService.java @@ -252,12 +252,51 @@ public Long cancelOrder(CancelOrderDto model) { /** - * todo 只更新了订单状态,后续操作待增加 + * 更新订单状态 + * 增加一条取消订单积分退回的记录 + * 查询所有的订单详情,依次库存增加,销量减少 */ ScoreOrder scoreOrder = new ScoreOrder(); scoreOrder.setId(model.getId()); scoreOrder.setStatus(ScoreOrder.STATUS_CANCEL); scoreOrderMapper.updateByPrimaryKeySelective(scoreOrder); + + ScoreOrder order = scoreOrderMapper.selectByPrimaryKey(model.getId()); + Example exampleDetails = new Example(ScoreDetails.class); + Example.Criteria criteriaDetails = exampleDetails.createCriteria(); + criteriaDetails.andEqualTo("orderNo",order.getOrderNo()); + criteriaDetails.andEqualTo("userId",order.getUserId()); + criteriaDetails.andEqualTo("type",ScoreDetails.SCORE_TYPE_SHOPPING); + ScoreDetails scoreDetails = scoreDetailsMapper.selectOneByExample(exampleDetails); + if(ObjectUtil.isNotEmpty(scoreDetails)){ + AccountInfo accountInfo = accountInfoMapper.selectAccountInfoByUserId(order.getUserId()); + BigDecimal score = new BigDecimal(accountInfo.getCollectScore()); + BigDecimal remianScore = score.add(scoreDetails.getChangeScore()).setScale(0, BigDecimal.ROUND_DOWN); + ScoreDetails scoreDetailsRet = new ScoreDetails(); + scoreDetailsRet.setOrderNo(scoreDetails.getOrderNo()); + scoreDetailsRet.setUserId(scoreDetails.getUserId()); + scoreDetailsRet.setType(ScoreDetails.SCORE_TYPE_SHOPPING_RETURN); + scoreDetailsRet.setOriginalScore(score); + scoreDetailsRet.setCurrentScore(remianScore); + scoreDetailsRet.setChangeScore(scoreDetails.getChangeScore()); + scoreDetailsRet.setCreatedTime(new Date()); + scoreDetailsMapper.insert(scoreDetailsRet); + } + + Example exampleScoreOrderDetails = new Example(ScoreOrderDetails.class); + Example.Criteria criteriaScoreOrderDetails = exampleScoreOrderDetails.createCriteria(); + criteriaScoreOrderDetails.andEqualTo("orderId",order.getId()); + List<ScoreOrderDetails> scoreOrderDetails = scoreOrderDetailsMapper.selectByExample(exampleScoreOrderDetails); + if(CollUtil.isNotEmpty(scoreOrderDetails)){ + for(ScoreOrderDetails scoreOrderDetail : scoreOrderDetails){ + ScoreGoodsSku scoreGoodsSku = scoreGoodsSkuMapper.selectByPrimaryKey(scoreOrderDetail.getSkuId()); + if(ObjectUtil.isNotEmpty(scoreGoodsSku)){ + scoreGoodsSku.setStock(scoreGoodsSku.getStock() + scoreOrderDetail.getCnt()); + scoreGoodsSku.setQuantity(scoreGoodsSku.getQuantity() - scoreOrderDetail.getCnt()); + scoreGoodsSkuMapper.updateByPrimaryKey(scoreGoodsSku); + } + } + } return scoreOrder.getId(); } -- Gitblit v1.9.1