public ResponseStatus findAllFkRuleByFsId(String fsId) {
List<FkRule> fkRuleList = fkRuleRepository.findAllByFsIdAndStatusIsNotOrderBySort(fsId, -1);
//查询列表规则编号分组同时排好序,根据实体FkRule 的code分组,同时,创建LinkedHashMap 容器。这样能保证
插入的顺序,和取出的顺序一样,
LinkedHashMap<String, List<FkRule>> groupBy = fkRuleList.stream().collect(Collectors.groupingBy
(FkRule::getCode,LinkedHashMap::new,Collectors.toList()));
List<FkRuleVO> fkRuleVOList = new ArrayList<>();
for (Map.Entry<String, List<FkRule>> entry : groupBy.entrySet()) {
FkRuleVO fkRuleVO = new FkRuleVO();
fkRuleVO.setCode(entry.getKey());
fkRuleVO.setFkRuleList(entry.getValue());
fkRuleVOList.add(fkRuleVO);
}
return ResponseStatus.object(fkRuleVOList);
}
下面是groupingBy的参数说明
可以看到有三个参数,第一个参数就是key的Function
了,第二个参数是一个map工厂,也就是最终结果的容器,一般默认的是采用的HashMap::new
,最后一个参数很重要是一个downstream
,类型是Collector
,也是一个收集器,那就是说,这三个参数其实就是为了解决分组问题的
-
第一个参数:分组按照什么分类
-
第二个参数:分组最后用什么容器保存返回
-
第三个参数:按照第一个参数分类后,对应的分类的结果如何收集
其实一个参数的Collectors.groupingBy
方法的 ,第二个参数默认是HashMap::new
, 第三个参数收集器其实默认是Collectors.toList