使用JAVA8 filter对List多条件模糊筛选、单个参数多个值过滤、多个参数联合排序

对于从缓存中获取的list集合如果根据条件进行模糊查询呢?

条件根据indexName字段筛选需要的值

1、造数据

复制代码
List<ShardsInfoDto> shardsList = new ArrayList<>();
        ShardsInfoDto shardsInfoDto = new ShardsInfoDto();
        shardsInfoDto.setIndexName("chenming20210416");
        shardsInfoDto.setDocs(3);
        shardsInfoDto.setStore(2.0);
        ShardsInfoDto shardsInfoDto1 = new ShardsInfoDto();
        shardsInfoDto1.setIndexName("asdasd");
        shardsInfoDto1.setDocs(1);
        shardsInfoDto1.setStore(4.1);
        ShardsInfoDto shardsInfoDto2 = new ShardsInfoDto();
        shardsInfoDto2.setIndexName("chenmingasdhkask");
        shardsInfoDto2.setDocs(1);
        shardsInfoDto2.setStore(5.1);
        ShardsInfoDto shardsInfoDto3 = new ShardsInfoDto();
        shardsInfoDto3.setIndexName("asdfghjkl");
        shardsInfoDto3.setDocs(4);
        shardsInfoDto3.setStore(3.1);
        ShardsInfoDto shardsInfoDto4 = new ShardsInfoDto();
        shardsInfoDto4.setIndexName("lkjhgfds");
        shardsInfoDto4.setDocs(2);
        shardsInfoDto4.setStore(1.1);
        ShardsInfoDto shardsInfoDto5 = new ShardsInfoDto();
        shardsInfoDto5.setIndexName("erghjcvghui");
        shardsInfoDto5.setDocs(2);
        shardsInfoDto5.setStore(1.2);
        ShardsInfoDto shardsInfoDto6 = new ShardsInfoDto();
        shardsList.add(shardsInfoDto);
        shardsList.add(shardsInfoDto1);
        shardsList.add(shardsInfoDto3);
        shardsList.add(shardsInfoDto4);
        shardsList.add(shardsInfoDto2);
        shardsList.add(shardsInfoDto5);
        shardsList.add(shardsInfoDto6);
复制代码

2、模糊查询:

String indexName = "asd";
        shardsList = shardsList.stream().filter(ShardsInfoDto -> ShardsInfoDto.getIndexName()!=null&&ShardsInfoDto.getIndexName().indexOf(indexName) > -1).collect(Collectors.toList());
        shardsList.stream().forEach(ShardsInfoDto -> {
            System.out.println(ShardsInfoDto.getIndexName());
        });

ShardsInfoDto.getIndexName()!=null 判断防止空指针异常

输出结果:

 

 3、单个参数多个值过滤

List<String> shardStateList = new ArrayList<>();
        shardStateList.add("a");
        shardStateList.add("b");
        shardStateList.add("c");
        shardsList = shardsList.stream().filter(ShardsInfoDto -> shardStateList.contains(ShardsInfoDto.getShardStates())).collect(Collectors.toList());

4、多个参数联合排序:

复制代码
String docsFlag = "asc";
        String storeFlag = "desc";
        //排序
        Comparator<ShardsInfoDto> doc = null;
        if("asc".equals(docsFlag)){
            //docs升序
            doc = Comparator.nullsFirst(Comparator.comparing(ShardsInfoDto::getDocs, Comparator.nullsFirst(Integer::compareTo)));
        }else if("desc".equals(docsFlag)){
            //docs降序
            doc = Comparator.nullsFirst(Comparator.comparing(ShardsInfoDto::getDocs, Comparator.nullsFirst(Integer::compareTo)).reversed());
        }
        Comparator<ShardsInfoDto> store = null;
        if("asc".equals(storeFlag)){
            //store升序
            store = Comparator.nullsFirst(Comparator.comparing(ShardsInfoDto::getStore, Comparator.nullsFirst(Double::compareTo)));
        }else if("desc".equals(storeFlag)){
            //store降序
            store = Comparator.nullsFirst(Comparator.comparing(ShardsInfoDto::getStore, Comparator.nullsFirst(Double::compareTo)).reversed());
        }
        // 联合排序
        Comparator<ShardsInfoDto> finalComparator = doc.thenComparing(store);
        shardsList.sort(finalComparator);
        for (ShardsInfoDto dto:shardsList) {
            System.out.println("doc:"+dto.getDocs()+",store:"+dto.getStore());
        }
复制代码

Comparator.nullsFirst()防止参数为空导致空指针异常!

结果:

 

 https://blog.csdn.net/qq_19201215/article/details/115973047

posted @   wq9  阅读(5367)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
历史上的今天:
2019-01-10 设计模式分类
点击右上角即可分享
微信分享提示