lambda表达式在解决java后台分组排序时的应用
需求:按照起始日期查询出数据库里一段连续日期的住院信息。
问题:数据库里的住院信息可能不是完整的,也就是在给出的日期区间里只有若干天的数据,缺少某些日期的数据。
解决:
1.需要我们先按日期分组查出数据库里有的数据;
2.然后遍历日期,将不存在的日期以日期为key,value为null插入集合里;
3.对集合里的key即日期进行排序。
注:这里分组和排序都用JDK8的新特性lambda表达式
1 /** 2 * 3 * @param startTime 开始时间 4 * @param endTime 结束时间 5 * @param tbOrderExecutionExample 模糊查询 6 * @return 结果集 7 * @throws ParseException 转换异常 8 */ 9 private Map<String, List<TBOrderExecution>> getListMap(@RequestParam(value = "startTime", required = false) String startTime, @RequestParam(value = "endTime", required = false) String endTime, TBOrderExecutionExample tbOrderExecutionExample) throws ParseException { 10 List<TBOrderExecution> list = tbDocOrderAdmissionService.selectByExample(tbOrderExecutionExample); 11 //获取时间段分组 12 SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd"); 13 List<String> lists = DateRangUtil.getAllDate(startTime, endTime); 14 Map<String, List<TBOrderExecution>> map = list.stream().collect(Collectors.groupingBy(x -> sdf2.format(x.getYzjhksrq()))); 15 Set<String> keys = map.keySet(); 16 Map<String, List<TBOrderExecution>> finalMap = map; 17 lists.forEach(ele -> { 18 if (!keys.contains(ele)) { 19 finalMap.put(ele, null); 20 } 21 22 }); 23 Map<String, List<TBOrderExecution>> finalMaps = new LinkedHashMap<>(); 24 Set<String> strings = finalMap.keySet(); 25 List<String> dates = new ArrayList<>(strings); 26 DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); 27 Collections.sort(dates, new Comparator<String>() { 28 DateFormat f = new SimpleDateFormat("yyyy-MM-dd"); 29 30 @Override 31 public int compare(String o1, String o2) { 32 try { 33 return f.parse(o1).compareTo(f.parse(o2)); 34 } catch (ParseException e) { 35 throw new IllegalArgumentException(e); 36 } 37 } 38 }); 39 dates.forEach(ele -> { 40 finalMap.forEach((key, value) -> { 41 if (key.equals(ele)) { 42 finalMaps.put(ele, value); 43 } 44 }); 45 }); 46 return finalMaps; 47 }
下面贴出生成给定起始日期生成连续日期的代码:
1 public static List<String> getAllDate(String start, String end) throws ParseException { 2 List<Date> lDate = new ArrayList<>(); 3 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); 4 Date dBegin = sdf.parse(start); 5 Date dEnd = sdf.parse(end); 6 7 lDate.add(dBegin); 8 Calendar calBegin = Calendar.getInstance(); 9 // 使用给定的 Date 设置此 Calendar 的时间 10 calBegin.setTime(dBegin); 11 Calendar calEnd = Calendar.getInstance(); 12 // 使用给定的 Date 设置此 Calendar 的时间 13 calEnd.setTime(dEnd); 14 // 测试此日期是否在指定日期之后 15 while (dEnd.after(calBegin.getTime())) { 16 // 根据日历的规则,为给定的日历字段添加或减去指定的时间量 17 calBegin.add(Calendar.DAY_OF_MONTH, 1); 18 lDate.add(calBegin.getTime()); 19 } 20 List<String> allDate = new ArrayList<>(); 21 lDate.forEach(ele -> allDate.add(sdf.format(ele))); 22 return allDate; 23 24 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
2017-10-10 java里判断字符串是否为数字类型的方法