List对象合并后进行排序

List对象合并后进行排序

业务场景

用户相关字段数量较多时,会进行分表,用相同的id进行关联,而后进行数据查询时,需要将两张或者多张表的数据进行拼接

思路:将其中一个list1转换为map,遍历list2,通过list2对象的属性获取map值,进行拼接

实现举例

需求

现在需要将以下两个列表根据ID进行合并,然后根据年龄排序

image-20220615175752273

实现

  1. 将其中一个list转化成map,以id为key值,对象为value,此处选用userExtend
        //以id为key值,将list转换为Map
        Map<String, UserExtend> userExtendMap = userExtends.stream()
                .collect(Collectors.toMap(UserExtend::getId, userExtend -> userExtend));

image-20220616092556300

  1. 通过流的方式拼接对象
        //通过流的方式拼接两个对象成为新对象
        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());
  1. 拼接完成

image-20220616092647510

  1. 使用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);

image-20220616102239689

Comparator参考博客

代码Demo

链接:https://pan.baidu.com/s/1g6jWbA5Ocb93C8qqqsx_Ig
提取码:cfxy

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值