累加 map java_java8利用lambda表达式对map集合进行分组求和,求最大值,平均值

List> counts = cardMapper.getCount(map);//查询数据库得到的map集合

List> result =new ArrayList<>();

Map>> glist = counts.stream().collect(Collectors.groupingBy(e -> e.get("card_id").toString()+"#"+e.get("channel_id").toString()+"#"+e.get("store_id")));//对card_id,channel_id,store_id进行分组

//对member_num求和,其他字段原样返回

glist.forEach((k,slist)->{

Map nmap=new HashMap<>();

IntSummaryStatistics sumcc = slist.stream().collect(Collectors.summarizingInt(e->Integer.valueOf(e.get("member_num").toString())));

nmap.put("card_id", slist.get(0).get("card_id"));

nmap.put("channel_id", slist.get(0).get("channel_id"));

nmap.put("member_num", sumcc.getSum());//求和

nmap.put("store_id",slist.get(0).get("store_id"));

nmap.put("area_id",slist.get(0).get("area_id"));

nmap.put("shop_type",slist.get(0).get("shop_type"));

result.add(nmap);

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值