目前实习有一个业务需求,即查询某一个数据近一年的12个月的所有数据,数据在mysql中的日期按varchar存储,只精确到月份如2024-05,使用LocalDate来获取过去12个月的时间戳数据,代码如下:
String bizDate = "2024-05-21";
List<String> dateList = new ArrayList<>();
LocalDate date = LocalDate.parse(bizDate,DateTimeFormatter.ISO_LOCAL_DATE);
//起始时间点
LocalDate startDate = date.minusMonth(11);
//结束时间点 即为当前时间点
LocalDate endDate = date.minusMonth(0);
//设置输出格式,只保存年月
DateTimeFormmater outDate = DateTimeFormmater.ofPattern("yyyy-MM");
while(!startDate.isAfter(endDate)){//如果开始时间下一个月是结束时间则结束循环 本代码中即
//startDate = 2024-06-21时候结束循环
dateList.add(startDate.format(outDate))//格式化时间戳为日-月
startDate = startDate.plusMonth(1);//增加一个月时间
}
上述代码就获取到了当前日期之前的十二个月的日期时间戳。
还有一个业务就是查数据近一个月的波动性,需要查找近30天的每一天的日期时间戳,格式和上面的一样,不过精确到日,类似为"2024-05-21",代码如下:
//时间戳格式
String bizDate = "2024-05-21";
//近一个月每天的时间戳列表
List<String> dateList = new ArrayList<>();
//字符串时间戳转LocalDate类型
LocalDate date = LocalDate.parse(bizDate,LocalDate.ISO_LOCAL_DATE);
//设置时间戳输出格式
DateTimeFormmater outDate = DateTimeFormmater.ofPattern("yyyy-MM-dd");
dateList.add(date);
//将前29天的日期都加到时间戳列表中
for(int i = 1; i< 30; i++){
LocalDate previousDate = date.minusDays(i);
dateList.add(previousDate.format(outDate));
}