场景
Java中从数据库中查询出某对象的list,需要根据某个属性进行去重,并且如果有重复的话
自定义取舍的保留规则。
比如从数据库中查询出上面结构的对象的list,需要根据car_Number字段去重,如果有重复则保留id字段最小的一条数据。

注:
博客:
https://blog.csdn.net/badao_liumang_qizhi
实现
思路是使用java的stream的groupingBy先按照car_Number进行分组,然后判断
分组后的每组的数量是否大于1,如果大于1,再取id最小的数据。
最后将数据存储到map中并返回。
public Map<String, String> getCarDriverMap(List<BusMailList> busMailLists) { try { Map<String, String> busMailListMap = new HashMap<>(); //去重,如果有重复则取id最小的数据 Map<String, List<BusMailList>> collect = busMailLists.stream().collect(Collectors.groupingBy(BusMailList::getCarNumber)); collect.forEach((key, value) -> { Optional<BusMailList> busMailList; if (value.size() > 1) { busMailList = value.stream().min(Comparator.comparing(BusMailList::getId)); } else { busMailList = Optional.ofNullable(value.get(0)); } busMailListMap.put(busMailList.get().getCarNumber(), busMailList.get().getDriverName()); }); return busMailListMap; }catch (Exception exception){ System.out.println("getCarDriverMap异常:"+exception.getMessage()); return new HashMap<>(); } }
调用该方法测试

分组之后,比如这里有2条,一个id是221,一个id是252,再取最小值之后

取得是较小的数据。