场景
Java中从数据库中查询出某对象的list,需要根据某个属性进行去重,并且如果有重复的话
自定义取舍的保留规则。
比如从数据库中查询出上面结构的对象的list,需要根据car_Number字段去重,如果有重复则保留id字段最小的一条数据。
注:
博客:
霸道流氓气质的博客_CSDN博客-C#,架构之路,SpringBoot领域博主
实现
思路是使用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,再取最小值之后
取得是较小的数据。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/135797.html