很多情況下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()));//先以屬性一升序,再進行屬性二降序<br><br><br>