对list集合进行排序并分页

有时候我们要对不同的数据类型进行排序的时候,一般得取出所有的数据(当然数据量不是上百万的级别),然后对不同的数据类型进行排序,今天在公司学到一种方法,利用了JDK1.8的特性吧,然后先是根据指定排序后,在进行分页.
在这里记录一下

//方法:
//datas是查询出来的数据,sort是升还是降排序,order是对某个数据排序
public List<T> builderDatas(List<T> datas,Integer currentPage, Integer pageSize, String sort, String order){
        Stream<T> streDatas = datas.stream();
        Long skipNumber = (currentPage - 1) * pageSize.longValue();
        //利用了Comparator, 因为不知道要排序的数据是什么类型的,所以都弄了,如果还有其他的类型,可以考虑
        Comparator<Long> longComparator = Comparator.nullsLast(Comparator.naturalOrder());
        Comparator<Integer> integerComparator = Comparator.nullsLast(Comparator.naturalOrder());
        //降序判断
        if (StringUtils.isBlank(order) || "desc".equals(order)) {
            longComparator = longComparator.reversed();
            integerComparator = integerComparator.reversed();
        }
 
        //根据传过来的数据种类,对单一种类进行排序
        switch(order){
           case A:  
                  streDatas = streDatas .sorted(Comparator.comparing(T::getA, longComparator));
                  break;
           case B:
                  streDatas = streDatas .sorted(Comparator.comparing(T::getB, integerComparator ));
                  break;
           default:
                 break; 
        }
        //最后返回分页的数据.
        return streDatas.skip(skipNumber).limit(pageSize).collect(Collectors.toList());

}

一些代码注解已经写好了,这段代码基本上都使用了JDK1.8 的stream()流的新特性,还有comparator的用法.
同时查过资料得知:skip.limit的本质是sublist,如果有不对的地方,欢迎指正

猜你喜欢

转载自blog.csdn.net/qq_37746072/article/details/85761100