java编码实现根据某个字段分组,再统计某个值

本文介绍了如何使用Java结合MyBatis框架,根据数据库中的某个字段进行数据分组,并对分组后的数据进行统计操作,具体实现包括数据库实体类和输出实体类的设计与使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实现层逻辑如下:

@Override
    public DesignChangeChangedAmountVo queryChangedAmounts() {
        List<DesignChange> designChangeList = this.lambdaQuery()
                .eq(DesignChange::getStatus, Constants.DesignChangeStatus.SHEN_PI_TONG_GUO)
                .eq(DesignChange::getDelFlag, CommonConstant.DEL_FLAG_0)
                .list();

        DesignChangeChangedAmountVo result = new DesignChangeChangedAmountVo();
        //根据合同分组
        Map<String, List<DesignChange>> contractMap = designChangeList.stream()
                .collect(Collectors.groupingBy(DesignChange::getContractId));

        List<DesignChangeChangedAmountVo.ContractTotalChangedAmounts> contracts = new ArrayList<>();
        contractMap.keySet().forEach(i -> {
            List<DesignChange> ls = contractMap.get(i);
            DesignChangeChangedAmountVo.ContractTotalChangedAmounts info = new DesignChangeChangedAmountVo.ContractTotalChangedAmounts();
            info.setContractId(ls.get(0).getContractId());
            info.setContractName(ls.get(0).getContractName());
            //累计造价咨询单位审核金额
            BigDecimal totalChangedAmount = ls.stream().map(DesignChange::getCostConsultUnitAuditAmount)
                    .filter(Objects::nonNull)
                    .reduce(BigDecimal.ZERO, BigDecimal::add);
            info.setContractTotalChangedAmount(totalChangedAmount);
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值