如图,数据库查出来的数据:
需求是按menu_id和menu_name分组,stream实现最简单,
stream里面只有按一个属性分组的,但是可以利用string简单变换一下:
List<JsonObject> list = goodsList.getList(); Map<String, List<JsonObject>> menuGroupMap = list.stream().collect(Collectors.groupingBy(goods -> goods.getInteger("menu_id")+"_"+goods.getString("menu_name"))); List<JsonObject> countRecords = menuGroupMap.keySet().stream().map(key -> { String[] temp = key.split("_"); String menu_id = temp[0]; String menu_name = temp[1]; JsonObject goodObject = new JsonObject(); goodObject.put("menu_id",menu_id); goodObject.put("menu_name",menu_name); goodObject.put("goodList",menuGroupMap.get(key)); goodObject.put("goodNum",menuGroupMap.get(key)); return goodObject; }).collect(Collectors.toList());
可以先利用 menu_id + _ menu_name 分组,然后再拼接组装数据,最后得出想要的结果: