有时候我们要对不同的数据类型进行排序的时候,一般得取出所有的数据(当然数据量不是上百万的级别),然后对不同的数据类型进行排序,今天在公司学到一种方法,利用了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,如果有不对的地方,欢迎指正