很多情况下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}
来源:https://www.cnblogs.com/qxqzx/p/12188520.html