List对象合并后进行排序
业务场景
用户相关字段数量较多时,会进行分表,用相同的id进行关联,而后进行数据查询时,需要将两张或者多张表的数据进行拼接
思路:将其中一个list1转换为map,遍历list2,通过list2对象的属性获取map值,进行拼接
实现举例
需求
现在需要将以下两个列表根据ID进行合并,然后根据年龄排序
实现
- 将其中一个
list
转化成map
,以id
为key值,对象为value,此处选用userExtend
//以id为key值,将list转换为Map
Map<String, UserExtend> userExtendMap = userExtends.stream()
.collect(Collectors.toMap(UserExtend::getId, userExtend -> userExtend));
- 通过流的方式拼接对象
//通过流的方式拼接两个对象成为新对象
List<UserDetail> userDetails = userList.stream().map(a->{
UserDetail userDetail = new UserDetail();
userDetail.setId(a.getId());
userDetail.setName(a.getName());
userDetail.setAge(a.getAge());
userDetail.setWork(userExtendMap.get(a.getId()).getWork());
return userDetail;
}).collect(Collectors.toList());
- 拼接完成
- 使用Comparator进行排序
//查看拼接后的对象
System.out.println(userDetails);
//方式一:使用比较器进行升序比较比较
Collections.sort(userDetails, new Comparator<UserDetail>() {
@Override
public int compare(UserDetail o1, UserDetail o2) {
return o1.getAge().compareTo(o2.getAge());
}
});
System.out.println(userDetails);
//方式二:以流的方式进行降序排序,去掉reversed()则为升序
List<UserDetail> newUserDetails = userDetails.stream().sorted(Comparator.comparing(UserDetail::getAge,
Comparator.nullsFirst(Integer::compareTo)).reversed()).collect(Collectors.toList());
System.out.println(newUserDetails);
代码Demo
链接:https://pan.baidu.com/s/1g6jWbA5Ocb93C8qqqsx_Ig 提取码:cfxy