轉載:https://www.cnblogs.com/kuanglongblogs/p/11230250.html
很多情況下sql不好解決的多表查詢,臨時表分組,排序,盡量用java8新特性stream進行處理
使用java8新特性,下面先來點基礎的
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
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>
|
通過以上例子我們可以發現
1. Comparator.comparing(類::屬性一).reversed();
2. Comparator.comparing(類::屬性一,Comparator.reverseOrder());
兩種排序是完全不一樣的,一定要區分開來 1 是得到排序結果后再排序,2是直接進行排序,很多人會混淆導致理解出錯,2更好理解,建議使用2
實際例子:
現有一個類test 有兩個屬性:state 狀態 time 時間,需要狀態順序且時間倒序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
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) {
this
.state = state;
}
public
Date getTime() {
return
time;
}
public
void
setTime(Date time) {
this
.time = time;
}
@Override
public
String toString() {
return
"test{"
+
"state="
+ state +
", time="
+ DateUtils.formatDateYMD(time) +
'}'
;
}
}
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
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);
}
for
(
int
i =
1
; i <=
3
; i++) {
test t =
new
test(i, DateUtils.addMonths(d, i));
testList.add(t);
}
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 -> {
System.out.println(o.toString());
});
}
}
|
運行結果:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
排序前:
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
}
------------------------------------
排序后:
test{state=
1
, time=
2019
-
08
-
23
}
test{state=
1
, time=
2019
-
07
-
24
}
test{state=
2
, time=
2019
-
09
-
23
}
test{state=
2
, time=
2019
-
07
-
25
}
test{state=
3
, time=
2019
-
10
-
23
}
test{state=
3
, time=
2019
-
07
-
26
}
Process finished with exit code
0
|
很多情況下sql不好解決的多表查詢,臨時表分組,排序,盡量用java8新特性stream進行處理
使用java8新特性,下面先來點基礎的
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
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>
|
通過以上例子我們可以發現
1. Comparator.comparing(類::屬性一).reversed();
2. Comparator.comparing(類::屬性一,Comparator.reverseOrder());
兩種排序是完全不一樣的,一定要區分開來 1 是得到排序結果后再排序,2是直接進行排序,很多人會混淆導致理解出錯,2更好理解,建議使用2
實際例子:
現有一個類test 有兩個屬性:state 狀態 time 時間,需要狀態順序且時間倒序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
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) {
this
.state = state;
}
public
Date getTime() {
return
time;
}
public
void
setTime(Date time) {
this
.time = time;
}
@Override
public
String toString() {
return
"test{"
+
"state="
+ state +
", time="
+ DateUtils.formatDateYMD(time) +
'}'
;
}
}
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
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);
}
for
(
int
i =
1
; i <=
3
; i++) {
test t =
new
test(i, DateUtils.addMonths(d, i));
testList.add(t);
}
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 -> {
System.out.println(o.toString());
});
}
}
|
運行結果:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
排序前:
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
}
------------------------------------
排序后:
test{state=
1
, time=
2019
-
08
-
23
}
test{state=
1
, time=
2019
-
07
-
24
}
test{state=
2
, time=
2019
-
09
-
23
}
test{state=
2
, time=
2019
-
07
-
25
}
test{state=
3
, time=
2019
-
10
-
23
}
test{state=
3
, time=
2019
-
07
-
26
}
Process finished with exit code
0
|