使用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()防止參數為空導致空指針異常!
結果:


————————————————
版權聲明:本文為CSDN博主「東耳佳茗」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/qq_19201215/article/details/115973047


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM