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

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

方式1

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

方式2

List 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> map = list.stream().collect(Collectors.groupingBy(MidDeliveryAreaFresh::getDeliveryAreaCode));
        List> groupList = map.values().stream().collect(Collectors.toList());
        List resultList = groupList.stream().map(listv -> listv.get(listv.size() - 1)).collect(Collectors.toList());

 

你可能感兴趣的:(stream,java)