java8 stream多字段排序的實現
很多情況下sql不好解決的多表查詢,臨時表分組,排序,盡量用java8新特性stream進行處理
使用java8新特性,下面先來點基礎的
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()));//先以屬性一升序,再進行屬性二降序
通過以上例子我們可以發現
1. Comparator.comparing(類::屬性一).reversed();
2. Comparator.comparing(類::屬性一,Comparator.reverseOrder());
兩種排序是完全不一樣的,一定要區分開來 1 是得到排序結果後再排序,2是直接進行排序,很多人會混淆導致理解出錯,2更好理解,建議使用2
實際例子:
現有一個類test 有兩個屬性:state 狀態 time 時間,需要狀態順序且時間倒序
class test { //狀態 private int state; //時間 private Date time; public test(int state, Date time) { this.state = state; this.time = time; } public int getState() { return state; public void setState(int state) { public Date getTime() { return time; public void setTime(Date time) { @Override public String toString() { return "test{" + "state=" + state + ", time=" + DateUtils.formatDateYMD(time) + '}'; }
class testRun { public static void main(String[] args) { List<test> testList = new ArrayList<>(); Date d = DateUtils.now(); for (int i = 1; i <= 3; i++) { test t = new test(i, DateUtils.addDays(d, i)); testList.add(t); } test t = new test(i, DateUtils.addMonths(d, i)); testList.forEach(o -> { System.out.println(o.toString()); }); List<test> sort = testList.stream().sorted(Comparator.comparing(test::getState).thenComparing(test::getTime,Comparator.reverseOrder())).collect(toList()); System.out.println("------------------------------------"); sort.forEach(o -> {
運行結果:
排序前:
test{state=1, time=2019-07-24}
test{state=2, time=2019-07-25}
test{state=3, time=2019-07-26}
test{state=1, time=2019-08-23}
test{state=2, time=2019-09-23}
test{state=3, time=2019-10-23}
————————————
排序後:
Process finished with exit code 0
到此這篇關於java8 stream多字段排序的實現的文章就介紹到這瞭,更多相關java8 stream多字段排序內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Java stream sorted使用 Comparator 進行多字段排序的方法
- java8 使用stream排序空字段排在前面或後面
- java8 stream的多字段排序實現(踩坑)
- Java Comparator.comparing比較導致空指針異常的解決
- Java8中Stream的詳細使用方法大全