zoukankan      html  css  js  c++  java
  • java8 stream多字段排序,以及空/Null字段排序与分组

     

     

    很多情况下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}
    复制代码
  • 相关阅读:
    【设计模式】备忘录
    统计ip的发送频率和该ip发送的有效消息(去除相似消息)的数目
    Android之消息推送聊天实现
    Dictionary通过下标获取key和value
    SGU 271 水题。。。。
    二叉树递归和非递归遍历
    C#与SSL
    正则表达式总结
    SQL Server User Accounts
    嵌入式领域中各种文件系统的比较
  • 原文地址:https://www.cnblogs.com/deepalley/p/15432071.html
Copyright © 2011-2022 走看看