场景

获取到了员工对象的list,每个员工对象有一个部门Id的属性,怎样根据这个部门id实现将这个list进行分组,

使部门id相同的分在一组。

具体实现效果类似于sql 查询中的group by。

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

首先获取这个对象的list

List<KqsjTian> kqsjTianList = kqsjTianService.tjselectkqsj(kqsjSelectParam);

其中KqsjTian是对象,其有部门id属性

Map<Long, List<KqsjTian>> bmListMap = new HashMap<Long, List<KqsjTian>>();
bmListMap = kqsjTianList.stream().collect(Collectors.groupingBy(kqsjTian -> kqsjTian.getBmid()));

然后调用list的stream方法再调用collect方法,前面声明的map第一个参数是分组的依据。

这里是部门id是long型的,所以第一个参数是Long型的,然后kqsjTian.getBmid()是获取每个对象的部门id属性。

获取分组后的数据的大概数据结构如下

获取之后就可以遍历这个map进行分别的处理

for (Map.Entry<Long, List<KqsjTian>> entry : bmListMap.entrySet()) {
 List<KqsjTian> currnrtbmList = entry.getValue();
            for (KqsjTian kqsjTian:currnrtbmList) {
                //计算考勤人数
                if(kqsjTian.getKqzt()!=null && Constants.KQZT_ZC.contains(kqsjTian.getKqzt()))
                {
                    kqrs++;
                }
            }
}

每一个entry是一组bmid相同的list,要获取每一个entry的key即部门id

entry.getKey()

获取每个的value

List<KqsjTian> currnrtbmList = entry.getValue();
posted on 2020-08-18 16:28  霸道流氓  阅读(2600)  评论(0编辑  收藏  举报

Live2D