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     }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM