根据起止日期生成连续日期

根据起止日期生成连续的日期,又两种方法,如下:

--- 方法一

select ContractRoomID,dateadd(day,number,'2016-07-15'),0 from ContractRoom cc

left join master.dbo.spt_values on   number <=DATEDIFF(day,'2016-07-15','2016-08-15')

where cc.ContractRoomID='R150006716C001' and type ='P'

结果:
这里写图片描述


 --- 方法二,这种方法只能在MSSQL 2008 以上版本中执行, 使用了CTE公共表达式中递归的思想

declare  @t  table(id varchar(50) , bizdate date);

declare @startDate date = '2016-06-01'; 

declare @EndDate date =  '2016-08-15' ;

with cte0 as 

(select   'R160016001' as contractRoomId , @startDate as startDate, @EndDate as endDate ), 

cte1 As 
(

    Select  contractRoomId , startDate As targetDate from cte0 

    union all

    Select contractRoomId , dateadd(day,1,targetDate) From cte1 

    Where dateadd(day,1,targetDate)<=@EndDate 
)  

insert into @t (id, bizdate)

select contractRoomId, targetDate From cte1  ;

select  * from @t

结果:
这里写图片描述

方法2的递归思想,可参考
Actual Practice : [with CTE]&[convert]&[coalesce] as in my work - 4

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
A: 实现这个功能可以使用Java标准库中的LocalDate类。具体实现步骤如下: 1. 定义起时间和日期格式 ``` String startDateStr = "2021-01-01"; String endDateStr = "2021-01-15"; DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); ``` 2. 转换起时间为LocalDate类型 ``` LocalDate startDate = LocalDate.parse(startDateStr, formatter); LocalDate endDate = LocalDate.parse(endDateStr, formatter); ``` 3. 循环遍历日期范围,按天拆分日期 ``` List<LocalDate> dateList = new ArrayList<>(); while (!startDate.isAfter(endDate)) { dateList.add(startDate); startDate = startDate.plusDays(1); } ``` 4. 输出拆分后的日期列表 ``` for (LocalDate date : dateList) { System.out.println(date.format(formatter)); } ``` 完整代码示例: ``` import java.time.LocalDate; import java.time.format.DateTimeFormatter; import java.util.ArrayList; import java.util.List; public class SplitDateByDay { public static void main(String[] args) { String startDateStr = "2021-01-01"; String endDateStr = "2021-01-15"; DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); LocalDate startDate = LocalDate.parse(startDateStr, formatter); LocalDate endDate = LocalDate.parse(endDateStr, formatter); List<LocalDate> dateList = new ArrayList<>(); while (!startDate.isAfter(endDate)) { dateList.add(startDate); startDate = startDate.plusDays(1); } for (LocalDate date : dateList) { System.out.println(date.format(formatter)); } } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值