实习笔记之LocalDate使用。

目前实习有一个业务需求,即查询某一个数据近一年的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));
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值