huliguo
2 天以前 8059e9b991c15edbac508e6b658a0d9571d11b1c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
package com.ruoyi.goods.service.impl.goods;
 
 
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.goods.domain.pojo.goods.GoodsTotal;
import com.ruoyi.goods.mapper.goods.GoodsTotalMapper;
import com.ruoyi.goods.service.goods.GoodsTotalService;
import com.ruoyi.system.api.domain.dto.GoodsTotalChangeDto;
import org.springframework.stereotype.Service;
 
import java.util.ArrayList;
import java.util.List;
 
/**
 * <p>
 * 商品统计 服务实现类
 * </p>
 *
 * @author jqs
 * @since 2023-04-25
 */
@Service
public class GoodsTotalServiceImpl extends ServiceImpl<GoodsTotalMapper, GoodsTotal> implements GoodsTotalService {
 
 
    /**
     * @description  更新商品统计
     * @author  jqs
     * @date    2023/7/23 18:25
     * @param goodsTotalChangeDtoList
     * @return  void
     */
    @Override
    public void changeGoodsTotal(List<GoodsTotalChangeDto> goodsTotalChangeDtoList){
        log.error("商品统计变动"+goodsTotalChangeDtoList.toString());
        if (goodsTotalChangeDtoList != null && !goodsTotalChangeDtoList.isEmpty()) {
            // 创建一个空的GoodsTotal对象
            GoodsTotal goodsTotal;
            // 创建一个空的GoodsTotal列表
            List<GoodsTotal> goodsTotalList = new ArrayList<>();
            // 遍历goodsTotalChangeDtoList列表
            for (GoodsTotalChangeDto goodsTotalChangeDto : goodsTotalChangeDtoList) {
                // 根据goodsId获取对应的GoodsTotal对象
                goodsTotal = this.getById(goodsTotalChangeDto.getGoodsId());
                // 如果GoodsTotal对象不为空
                if (goodsTotal != null) {
                    // 根据changeType判断操作类型
                    if (goodsTotalChangeDto.getChangeType() == 1) {
                        // 更新GoodsTotal对象的相关属性
                        goodsTotal.setBuyCount(goodsTotal.getBuyCount() + 1);
                        goodsTotal.setBuyNumCount(goodsTotal.getBuyNumCount() + goodsTotalChangeDto.getChangeNum());
                        goodsTotal.setBuyUserCount(goodsTotalChangeDto.getPersonNum());
                        goodsTotal.setBuyMoneyTotal(goodsTotal.getBuyMoneyTotal().add(goodsTotalChangeDto.getMoney()));
                    } else {
                        // 更新GoodsTotal对象的相关属性
                        goodsTotal.setBuyCount(goodsTotal.getBuyCount() - 1);
                        goodsTotal.setBuyNumCount(goodsTotal.getBuyNumCount() - goodsTotalChangeDto.getChangeNum());
                        goodsTotal.setBuyUserCount(goodsTotalChangeDto.getPersonNum());
                        goodsTotal.setBuyMoneyTotal(goodsTotal.getBuyMoneyTotal().subtract(goodsTotalChangeDto.getMoney()));
                    }
                    // 将更新后的GoodsTotal对象添加到列表中
                    goodsTotalList.add(goodsTotal);
                }
            }
            // 如果goodsTotalList列表不为空,则保存或更新列表中的GoodsTotal对象
            if (!goodsTotalList.isEmpty()) {
                this.saveOrUpdateBatch(goodsTotalList);
            }
        }
    }
}