stream流运用Tuple多元素分组

List<Map<String,Object>> childrenList = orderList.stream()
		                			.filter(fr2 -> getLong(fr2.get("shipApplyId")).equals(getLong(fh.get("id"))))
		    						.collect(Collectors.groupingBy(gb2 -> new Tuple(gb2.get("companyCode"), gb2.get("cargoInfoCode"), 
		    									gb2.get("tradeType"), gb2.get("inoutType"), gb2.get("cargoAgentId"), gb2.get("shipperId"))))
		    						.entrySet()
		    						.stream()
		    						.map(m2 -> {
		    							Map<String,Object> idMap = new HashMap<>();
		    							idMap.putAll(m2.getValue().get(0));
		    							
		    							
		    							String idList = m2.getValue().stream().map(m3 -> getString(m3.get("id"))).distinct().collect(Collectors.joining(","));
		    							idMap.put("idList", idList);
		    							
		    							idMap.put("fid", getLong(fh.get("id")));
		    							
		    							return idMap;
		    						}).collect(Collectors.toList());
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值