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