时间:2021-05-19
我就废话不多说了,大家还是直接看代码吧~
Map<String, List<CommentQuery>> commentList = list.stream().collect(Collectors.groupingBy(CommentQuery::getNewsId));for (Map.Entry<String, List<CommentQuery>> entry : commentList.entrySet()) {String key = HOT_LIST_KEY + entry.getKey();if (entry.getValue().isEmpty()) {stringRedisTemplate.opsForValue().set(key, "");} else {Gson gson = new Gson();String json = gson.toJson(entry.getValue());//先删除redis数据然后在插入新的牛评数据stringRedisTemplate.delete(key);stringRedisTemplate.opsForValue().set(key, json);stringRedisTemplate.expire(key, 1, TimeUnit.DAYS);}}补充知识:java8 list集合利用stream 根据元素的指定属性进行分组统计
需求是对指定集合的学生信息,根据班级分组统计每个班所有学生的凭证数量。
List<HashMap<String, Object>> result = new ArrayList<>(); List<HashMap<String, Object>> list = getList(countVo); list.stream() .collect(Collectors.groupingBy(map -> map.get("className"), Collectors.toList())) .forEach((key, groupMap) -> { HashMap<String, Object> stringObjectHashMap = groupMap.stream().reduce((item1, item2) -> { Integer pzListNo = item1.get("pzListNo") == null ? 0 : (Integer) item1.get("pzListNo"); Integer pzListNo2 = item2.get("pzListNo") == null ? 0 : (Integer) item2.get("pzListNo"); item1.put("pzListNo", pzListNo + pzListNo2); return item1; }).get(); result.add(stringObjectHashMap); }); return result;以上这篇使用jdk1.8实现将list根据指定的值去分组的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一.前言随着Java的发展,越来越多的企业开始使用JDK1.8版本。JDK1.8是自JDK1.5之后最重要的版本,这个版本包含语言、编译器、库、工具、JVM等方
jdk1.7和1.8的区别是: jdk1.8广义上来说是1.7的增强版,即1.8的功能更加强大,如:1.8中Switch语句支持string类型、Try-wi
准备工具:IDEA jdk1.8 NavicatforMySQL Postman一、新建Project选择依赖:mybatisWebMysqlJDBC项目
hashtable底层结构是数组加链表加红黑树(JDK1.8增加了红黑树部分)。 hashtable类实现一个哈希表,该哈希表将键映射到相应的值。任何非nul
问题描述本来使用的是jdk1.8,由于其他原因需要使用jdk1.6,在安装完jdk1.6后打开eclipse就会报错:Version1.6.0_43oftheJ