java8 stream多字段排序,以及空/Null字段排序與分組


 

 

很多情況下sql不好解決的多表查詢,臨時表分組,排序,盡量用java8新特性stream進行處理

使用java8新特性,下面先來點基礎的

https://www.cnblogs.com/codecat/p/10873757.html

 

復制代碼
List<類> list; 代表某集合
 
//返回 對象集合以類屬性一升序排序
list.stream().sorted(Comparator.comparing(類::屬性一));
 
//返回 對象集合以類屬性一降序排序 注意兩種寫法
list.stream().sorted(Comparator.comparing(類::屬性一).reversed());//先以屬性一升序,結果進行屬性一降序
list.stream().sorted(Comparator.comparing(類::屬性一,Comparator.reverseOrder()));//以屬性一降序
 
//返回 對象集合以類屬性一升序 屬性二升序
list.stream().sorted(Comparator.comparing(類::屬性一).thenComparing(類::屬性二));
 
//返回 對象集合以類屬性一降序 屬性二升序 注意兩種寫法
list.stream().sorted(Comparator.comparing(類::屬性一).reversed().thenComparing(類::屬性二));//先以屬性一升序,升序結果進行屬性一降序,再進行屬性二升序
list.stream().sorted(Comparator.comparing(類::屬性一,Comparator.reverseOrder()).thenComparing(類::屬性二));//先以屬性一降序,再進行屬性二升序
 
//返回 對象集合以類屬性一降序 屬性二降序 注意兩種寫法
list.stream().sorted(Comparator.comparing(類::屬性一).reversed().thenComparing(類::屬性二,Comparator.reverseOrder()));//先以屬性一升序,升序結果進行屬性一降序,再進行屬性二降序
list.stream().sorted(Comparator.comparing(類::屬性一,Comparator.reverseOrder()).thenComparing(類::屬性二,Comparator.reverseOrder()));//先以屬性一降序,再進行屬性二降序
 
//返回 對象集合以類屬性一升序 屬性二降序 注意兩種寫法
list.stream().sorted(Comparator.comparing(類::屬性一).reversed().thenComparing(類::屬性二).reversed());//先以屬性一升序,升序結果進行屬性一降序,再進行屬性二升序,結果進行屬性一降序屬性二降序
list.stream().sorted(Comparator.comparing(類::屬性一).thenComparing(類::屬性二,Comparator.reverseOrder()));//先以屬性一升序,再進行屬性二降序

//空/Null數據排序
list.stream().sorted(Comparator.comparing(類::屬性一).thenComparing(item -> item.屬性二, Comparator.nullsLast(Date::compareTo))).collect(Collectors.toList());

//空/Null數據分組
Map<String, List<類>> map = list.stream().collect(Collectors.groupingBy(item -> {
  if (item.屬性一 == null || item.屬性一.equals("")) {
    return "";
  }
  return DateFormat.getDateInstance().format(item.屬性一);
}))
復制代碼

通過以上例子我們可以發現

1. Comparator.comparing(類::屬性一).reversed();

2. Comparator.comparing(類::屬性一,Comparator.reverseOrder());

兩種排序是完全不一樣的,一定要區分開來 1 是得到排序結果后再排序,2是直接進行排序,很多人會混淆導致理解出錯,2更好理解,建議使用2

實際例子:

現有一個類test 有兩個屬性:state 狀態 time 時間,需要狀態順序且時間倒序

 

復制代碼
 1 class test {
 2     //狀態
 3     private int state;
 4     //時間
 5     private Date time;
 6  
 7     public test(int state, Date time) {
 8         this.state = state;
 9         this.time = time;
10     }
11  
12     public int getState() {
13         return state;
14     }
15  
16     public void setState(int state) {
17         this.state = state;
18     }
19  
20     public Date getTime() {
21         return time;
22     }
23  
24     public void setTime(Date time) {
25         this.time = time;
26     }
27  
28     @Override
29     public String toString() {
30         return "test{" +
31                 "state=" + state +
32                 ", time=" + DateUtils.formatDateYMD(time) +
33                 '}';
34     }
35 }
復制代碼
復制代碼
 1 class testRun {
 2     public static void main(String[] args) {
 3         List<test> testList = new ArrayList<>();
 4         Date d = DateUtils.now();
 5         for (int i = 1; i <= 3; i++) {
 6             test t = new test(i, DateUtils.addDays(d, i));
 7             testList.add(t);
 8         }
 9         for (int i = 1; i <= 3; i++) {
10             test t = new test(i, DateUtils.addMonths(d, i));
11             testList.add(t);
12         }
13  
14         testList.forEach(o -> {
15             System.out.println(o.toString());
16         });
17         List<test> sort = testList.stream().sorted(Comparator.comparing(test::getState).thenComparing(test::getTime,Comparator.reverseOrder())).collect(toList());
18         System.out.println("------------------------------------");
19         sort.forEach(o -> {
20             System.out.println(o.toString());
21         });
22  
23  
24     }
25 }
復制代碼

 

運行結果:

復制代碼
 1 排序前:
 2 test{state=1, time=2019-07-24}
 3 test{state=2, time=2019-07-25}
 4 test{state=3, time=2019-07-26}
 5 test{state=1, time=2019-08-23}
 6 test{state=2, time=2019-09-23}
 7 test{state=3, time=2019-10-23}
 8 ------------------------------------
 9 排序后:
10 test{state=1, time=2019-08-23}
11 test{state=1, time=2019-07-24}
12 test{state=2, time=2019-09-23}
13 test{state=2, time=2019-07-25}
14 test{state=3, time=2019-10-23}
15 test{state=3, time=2019-07-26}


復制代碼
 
 
minPriceList.stream().sorted(Comparator.comparing(l -> l.getCreateDate(), Comparator.nullsLast(Date::compareTo))).findFirst().get();


免責聲明!

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



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