場景
獲取到了員工對象的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();