1、第一种
//从数据库取的数据
List<User> saleTaskItemOldList = new ArrayList<>();
//从前端修改的数据
List<User> saleTaskItemNewList = new ArrayList<>();
//修改的
List<User> updateOldList = saleTaskItemNewList.stream()
.filter(item -> saleTaskItemOldList.stream()
.map(e -> e.getName())
.collect(Collectors.toList())
.contains(item.getName()))
.collect(Collectors.toList());
//删除的
List<User> deleteOldList = saleTaskItemOldList.stream()
.filter(item -> !saleTaskItemNewList.stream()
.map(e -> e.getName())
.collect(Collectors.toList())
.contains(item.getName()))
.collect(Collectors.toList());
//新的
List<User> newList = saleTaskItemNewList.stream()
.filter(item -> !saleTaskItemOldList.stream()
.map(e -> e.getName())
.collect(Collectors.toList())
.contains(item.getName()))
.collect(Collectors.toList());
//交集
List<User> sameList = saleTaskItemNewList.stream()
.filter(u1-> saleTaskItemOldList.contains(u1))
.collect(Collectors.toList());
//去重
List<User> userList = list1.stream()
.collect(Collectors.collectingAndThen(
Collectors.toCollection(() -> new TreeSet<>(
Comparator.comparing(user -> user.getName()))), ArrayList::new));
2、第二种
//从数据库取的数据
List<User> saleTaskItemOldList = new ArrayList<>();
//从前端修改的数据
List<User> saleTaskItemNewList = new ArrayList<>();
//修改的
List<User> updateOldList = saleTaskItemNewList.stream()
.filter(u1-> saleTaskItemOldList.contains(u1))
.collect(Collectors.toList());
//删除的
List<User> deleteOldList = saleTaskItemOldList.stream()
.filter(u1-> !saleTaskItemNewList.contains(u1))
.collect(Collectors.toList());
//新的
List<User> newList = saleTaskItemNewList.stream()
.filter(u1-> !saleTaskItemOldList.contains(u1))
.collect(Collectors.toList());
总结:使用对象中的属性比较精确,直接使用对象本身也是没问题的。
这篇博客探讨了如何使用Java集合流API来处理数据列表的变化。通过比较两个User对象列表,分别获取了修改、删除、新增的用户列表,并实现了列表的交集和去重操作。这种方法在数据同步和更新场景中非常实用。
2283

被折叠的 条评论
为什么被折叠?



