很多情況下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}