Java8 Collectors.groupingBy 按照数据库查询语句的排序 进行分组排序

一.groupingBy()的源码

public static <T, K, A, D>
Collector<T, ?, Map<K, D>> groupingBy(Function<? super T, ? extends K> classifier,
                                      Collector<? super T, A, D> downstream) {
    return groupingBy(classifier, HashMap::new, downstream);
}

三个参数

第一个参数:分组按照什么分类

第二个参数:分组最后用什么容器保存返回(默认是HashMap::new)

第三个参数:按照第一个参数分类后,对应的分类的结果如何收集(默认是Collectors.toList)

Collectors.groupingBy(SoureVo::getTime, LinkedHashMap::new,Collectors.toList())

LinkedHashMap实现了有序的HashMap,LinkedHashMap取键值对时,是按照你放入的顺序来取的(也就是sql查询出的顺序)

此外默认使用的HashMap是无序的,HashMap在put的时候是根据key的hashcode进行hash然后放入对应的地方,所以在按照一定顺序put进HashMap中,然后遍历出HashMap的顺序跟put的顺序不同。

Collectors.groupingBy(SoureVo::getTime, HashMap::new,Collectors.toList())

TreeMap是有序的,如果key是数值类型,默认升序,如果key为string或者对象,需要自己实现比较器。

Collectors.groupingBy(SoureVo::getTime, TreeMap::new,Collectors.toList())

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值