stream实现list根据对象中多个属性分组,并取分组后最新数据

业务场景:定时任务同步中间表数据到业务表,如果中间表中存在相同维度的多条数据(未创建唯一索引),取最新一条数据,并对查询的中间表数据进行更新。

方式1

  // 根据结果表唯一索引分组,取中间表重复最新一条
        Map<String, List<MidDeliveryAreaConfigFresh>> mapGroup = list.stream().collect(Collectors.groupingBy(v ->
                v.getDcCode() + v.getBigCategoryCode() + v.getSmallCategoryCode() + v.getProductCode() + v.getStockLoc()));
        List<MidDeliveryAreaConfigFresh> resultList = mapGroup.values().stream().map(listv -> listv.get(listv.size() - 1)).collect(Collectors.toList());

方式2

List<MidDeliveryAreaConfigFresh> resultList = list.stream().collect(Collectors.groupingBy(v -> new StringBuilder().append(v.getDcCode())
		.append(v.getBigCategoryCode()).append(v.getSmallCategoryCode()).append(v.getProductCode()).append(v.getStockLoc())))
		.values().stream().map(listv -> listv.get(listv.size() - 1));

方式2SonarLint检测工具不通过,方式1对方式2进行了拆分优化。

方式3,更详细拆分

  Map<String, List<MidDeliveryAreaFresh>> map = list.stream().collect(Collectors.groupingBy(MidDeliveryAreaFresh::getDeliveryAreaCode));
        List<List<MidDeliveryAreaFresh>> groupList = map.values().stream().collect(Collectors.toList());
        List<MidDeliveryAreaFresh> resultList = groupList.stream().map(listv -> listv.get(listv.size() - 1)).collect(Collectors.toList());

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值