【java8分页排序】lambda的(多字段)分页和排序 comparing,thenComparing的区别

  • A+
所属分类:Java

java8的lambda表达式排序,理应用comparing,多字段 后面增加thenComparing,默认排序规则为正序。

排序

现在有个排序需求:
a-倒序
b-当a相同时,正序
c-当b相同时,倒序

正确的写法:

 List<UserCouponVo> newList = list.stream().sorted(Comparator                    .comparing(UserCouponVo::getA,Comparator.reverseOrder())
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC,Comparator.reverseOrder())
            ).collect(Collectors.toList());

错误的写法:

 List<UserCouponVo> newList = list.stream().sorted(Comparator                    .comparing(UserCouponVo::getA).reversed()
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC).reversed()
            ).collect(Collectors.toList());

原因
Comparator.comparing(类属性).reversed() 是得到正序结果后再逆序 , .reversed() 是逆反前面的所有排序
Comparator.comparing(类属性,Comparator.reverseOrder()); 当前字段直接逆序。

所以,当需求为:
a-倒序
b-当a相同时,倒序
c-当b相同时,倒序

可以写成:

 List<UserCouponVo> newList = list.stream().sorted(Comparator                    .comparing(UserCouponVo::getA)
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC).reversed()
            ).collect(Collectors.toList());

所以,当需求为:
a-正序
b-当a相同时,正序
c-当b相同时,正序

可以写成:

 List<UserCouponVo> newList = list.stream().sorted(Comparator                    .comparing(UserCouponVo::getA)
                    .thenComparing(UserCouponVo::getB).reversed()
                    .thenComparing(UserCouponVo::getC).reversed()
            ).collect(Collectors.toList());

或:

 List<UserCouponVo> newList = list.stream().sorted(Comparator                    .comparing(UserCouponVo::getA)
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC)
            ).collect(Collectors.toList());

分页:

 List<UserCouponVo> newList = list.stream().sorted(Comparator                    .comparing(UserCouponVo::getA)
                    .thenComparing(UserCouponVo::getB)
                    .thenComparing(UserCouponVo::getC)
            ).skip((bo.getPage() - 1) * bo.getPageSize()).limit(bo.getPageSize())
            .collect(Collectors.toList());

有种mysql的既视感。

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: