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

实现层逻辑如下:

@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);
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Java的Elasticsearch High Level REST Client来实现根据某个字段正序查询的功能。具体的实现步骤如下: 1. 创建Elasticsearch客户端连接: ```java RestHighLevelClient client = new RestHighLevelClient( RestClient.builder(new HttpHost("localhost", 9200, "http"))); ``` 2. 构造查询请求: ```java SearchRequest searchRequest = new SearchRequest("index_name"); // 设置索引名称 SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.query(QueryBuilders.matchAllQuery()); // 设置查询条件,这里使用 matchAllQuery() 匹配所有文档 searchSourceBuilder.sort(new FieldSortBuilder("field_name").order(SortOrder.ASC)); // 设置排序规则,这里使用正序排序 searchRequest.source(searchSourceBuilder); ``` 其中,"index_name"代表要查询的索引名称,"field_name"代表要根据哪个字段排序。 3. 执行查询请求: ```java SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); ``` 4. 处理查询结果: ```java SearchHits hits = searchResponse.getHits(); for (SearchHit hit : hits) { // 处理每个文档的数据 } ``` 完整的示例代码如下: ```java RestHighLevelClient client = new RestHighLevelClient( RestClient.builder(new HttpHost("localhost", 9200, "http"))); SearchRequest searchRequest = new SearchRequest("index_name"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.query(QueryBuilders.matchAllQuery()); searchSourceBuilder.sort(new FieldSortBuilder("field_name").order(SortOrder.ASC)); searchRequest.source(searchSourceBuilder); SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); SearchHits hits = searchResponse.getHits(); for (SearchHit hit : hits) { // 处理每个文档的数据 } client.close(); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值