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     }
复制代码

 

posted on   德邦总管  阅读(1647)  评论(0编辑  收藏  举报

编辑推荐:
· 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里判断字符串是否为数字类型的方法
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示