用stream流判断数据中某个字段是否存在重复的数据,并返回其id
List<User> list = new ArrayList<>();
list.add(new User(1, "xiaoming", "123456", 4));
list.add(new User(2, "xiaoming", "123456", 5));
list.add(new User(3, "xiaodong", "234", 6));
list.add(new User(4, "xiaodong", "245", 7));
list.add(new User(5, "xiaoxi", "245", 10));
list.add(new User(6, "xiaobei", "225", 10));
//获取存在重复的数据
List<Map.Entry<String, List<User>>> collect = list.stream().collect(Collectors.groupingBy(User::getName))
.entrySet().stream().filter(e -> e.getValue().size() > 1).collect(Collectors.toList());
if(!collect.isEmpty()){
//name
List<String> collect2 = collect.stream().map(Map.Entry::getKey).collect(Collectors.toList());
//id
List<String> collect3 = collect.stream().map(e -> e.getValue().stream().map(user -> user.getId()+"").collect(Collectors.joining(",")))
.collect(Collectors.toList());
for (int i = 0; i < collect2.size(); i++) {
System.out.println("姓名:"+collect2.get(i)+",重复id:"+collect3.get(i));
}
}else {
System.out.println("不存在重复数据");
}
输出