获取数据状态最大且更新时间最新的数据四种排序方式

复制代码
    public static void main(String[] args) {
        List<MonthDTO> allDayDtos = getMonthDTOS();
        // 去除状态最大的数据
        allDayDtos.removeIf(data -> data.getStatus().equals("12") || data.getStatus().equals("99"));
        // 根据状态降序排序 第一种方式
        allDayDtos.sort(Comparator.comparing(MonthDTO::getStatus).reversed());
        // 按照区间分组
        Map<String, List<MonthDTO>> groupMap = new HashMap<>();
        for (MonthDTO monthDTO : allDayDtos) {
            String intervalKey = monthDTO.getStartDate() + "_" + monthDTO.getEndDate() + "-" + monthDTO.getVcCombiId() + "_" + monthDTO.getVcFeeType();
            groupMap.computeIfAbsent(intervalKey, k -> new ArrayList<>()).add(monthDTO);
        }
        // 处理每个区间的数据,获取数据状态最大且更新时间最新的数据
        List<MonthDTO> latestDataList = getPayManageDayDTOS(groupMap);
        System.out.println("第一种方式:" + latestDataList);

        // 第二种方式
        Map<String, Map<String, MonthDTO>> monthGroupMap = allDayDtos.stream()
                .collect(Collectors.groupingBy(MonthDTO::getId, Collectors.toMap(MonthDTO::getVcFeeType,Function.identity(), BinaryOperator.maxBy(Comparator.comparing(MonthDTO::getStatus)))));
        // 处理每个区间的数据,获取数据状态最大且更新时间最新的数据
        Map<String, MonthDTO> dtoMap = monthGroupMap.values().stream()
                .flatMap(group -> group.values().stream())
                .collect(Collectors.toMap(
                        data -> data.getId() + "_" + data.getVcFeeType() + "_" + data.getStartDate() + "_" + data.getEndDate(),
                        data -> allDayDtos.stream().filter(d -> d.getVcCombiId().equals(data.getVcCombiId()) &&
                                d.getVcFeeType().equals(data.getVcFeeType()) &&
                                d.getStatus().equals(data.getStatus()))
                                .max(Comparator.comparing(MonthDTO::getUpdateTime))
                                .orElse(data)));
        List<MonthDTO> latesr = new ArrayList<>(dtoMap.values());
        System.out.println("第二种方式:" + latesr);

        // 第三种方式
        List<MonthDTO> latestDataList3 = allDayDtos.stream()
                .collect(Collectors.groupingBy(d -> Arrays.asList(d.getStartDate(), d.getEndDate(), d.getVcCombiId(), d.getVcFeeType())))
                .values().stream()
                .map(group -> group.stream().max(Comparator.comparing(MonthDTO::getStatus).thenComparing(MonthDTO::getUpdateTime)).orElse(null))
                .filter(Objects::nonNull)
                .collect(Collectors.toList());
        System.out.println("第三种方式:" + latestDataList3);

        // 第四种方式
        List<MonthDTO> latestDataList4 = allDayDtos.stream()
                // 按照开始日期、结束日期、组合ID、类型分组
                .collect(Collectors.groupingBy(d -> d.getStartDate() + "_" + d.getEndDate() + "_" + d.getVcCombiId() + "_" + d.getVcFeeType()))
                // 对每个分组进行处理
                .values().stream()
                .map(group -> group.stream()
                        // 先按状态降序排序
                        .sorted(Comparator.comparing(MonthDTO::getStatus).reversed()
                        // 状态相同的按更新时间降序排序
                        .thenComparing(MonthDTO::getUpdateTime, Comparator.reverseOrder()))
                        // 取第一个(状态最大且更新时间最新)
                        .findFirst()
                        .get())
                // 收集结果
                .collect(Collectors.toList());
        System.out.println("第四种方式:" + latestDataList4);
    }

    @NotNull
    private static List<MonthDTO> getPayManageDayDTOS(Map<String, List<MonthDTO>> groupMap) {
        List<MonthDTO> latestDataList = new ArrayList<>();
        for (List<MonthDTO> monthDTOList : groupMap.values()) {
            MonthDTO monthDTO = monthDTOList.get(0);
            for (MonthDTO dto : monthDTOList) {
                if (dto.getStartDate().equals(monthDTO.getStartDate()) &&
                    dto.getEndDate().equals(monthDTO.getEndDate()) &&
                    dto.getStatus().equals(monthDTO.getStatus()) &&
                    dto.getUpdateTime().after(monthDTO.getUpdateTime())) {
                    monthDTO = dto;
                }
            }
            latestDataList.add(monthDTO);
        }
        return latestDataList;
    }

    private static List<MonthDTO> getMonthDTOS() {
        List<MonthDTO> allDayDtos = new ArrayList<>();
        MonthDTO dto = new MonthDTO();
        dto.setId("01");
        dto.setStartDate("20240101");
        dto.setEndDate("20240104");
        dto.setVcFeeType("GLF");
        dto.setVcCombiId("1105");
        dto.setStatus("7");
        dto.setUpdateTime(DateUtil.parseDate("2025-01-01"));
        allDayDtos.add(dto);

        MonthDTO dto1 = new MonthDTO();
        dto1.setId("01");
        dto1.setStartDate("20240101");
        dto1.setEndDate("20240104");
        dto1.setVcFeeType("YJBC");
        dto1.setVcCombiId("1105");
        dto1.setStatus("7");
        dto1.setUpdateTime(DateUtil.parseDate("2025-01-01"));
        allDayDtos.add(dto1);

        MonthDTO dto2 = new MonthDTO();
        dto2.setId("22");
        dto2.setStartDate("20240101");
        dto2.setEndDate("20240104");
        dto2.setVcFeeType("GLF");
        dto2.setVcCombiId("1105");
        dto2.setStatus("9");
        dto2.setUpdateTime(DateUtil.parseDate("2025-01-01"));
        allDayDtos.add(dto2);

        MonthDTO dto3 = new MonthDTO();
        dto3.setId("22");
        dto3.setStartDate("20240101");
        dto3.setEndDate("20240104");
        dto3.setVcFeeType("YJBC");
        dto3.setVcCombiId("1105");
        dto3.setStatus("9");
        dto3.setUpdateTime(DateUtil.parseDate("2025-01-01"));
        allDayDtos.add(dto3);

        return allDayDtos;
    }
相关推荐
JeffDingAI26 分钟前
【CANN训练营】在CANN8.5上体验Hello World开启Ascend C学习
c语言·开发语言·人工智能·学习
MyBFuture28 分钟前
C#表格与定时器实战技巧
开发语言·windows·c#·visual studio
YGGP34 分钟前
【Golang】LeetCode 2. 两数相加
开发语言·leetcode·golang
liuhaikang34 分钟前
鸿蒙高性能动画库——lottie-turbo
java·开发语言·nginx
Hcoco_me35 分钟前
大模型面试题41:RoPE改进的核心目标与常见方法
开发语言·人工智能·深度学习·自然语言处理·transformer·word2vec
Yy_Yyyyy_zz36 分钟前
2025 技术年终总结|近七年 Golang 工程实践、AI 应用落地与技术创作回顾
开发语言·golang·ai编程
面对疾风叭!哈撒给38 分钟前
Liunx之Docker 安装启动 influxdb2
java·spring cloud·docker
leiming639 分钟前
c++ transform算法
开发语言·c++·算法
沛沛老爹40 分钟前
Web开发者快速上手AI Agent:基于Function Calling的提示词应用优化实战
java·人工智能·llm·agent·web·企业开发·function
菩提祖师_43 分钟前
基于VR的虚拟会议系统设计
开发语言·javascript·c++·爬虫