这是我的数据的样子
ID StartDate EndDate
1 1/1/2019 1/15/2019
2 1/10/2019 1/11/2019
3 2/5/2020 3/10/2020
4 3/10/2019 3/19/2019
5 5/1/2020 5/4/2020
我正在尝试获取数据集中每个日期的列表,以及在该时间范围内属于该日期范围的ID数量。因此对于ID-1,它将记录在1/1 / 2019、1 / 2/2019 ...到1/15/2019。
我不确定该怎么做。感谢所有帮助。
答案 0 :(得分:1)
如果您没有日历表(强烈建议使用),则可以与临时计数表一起执行此任务,并与CROSS APPLY配合使用
示例
Declare @YourTable Table ([ID] varchar(50),[StartDate] date,[EndDate] date)
Insert Into @YourTable Values
(1,'1/1/2019','1/15/2019')
,(2,'1/10/2019','1/11/2019')
,(3,'2/5/2020','3/10/2020')
,(4,'3/10/2019','3/19/2019')
,(5,'5/1/2020','5/4/2020')
Select A.ID
,B.Date
From @YourTable A
Cross Apply (
Select Top (DateDiff(DAY,A.[StartDate],A.[EndDate])+1) Date=DateAdd(DAY,-1+Row_Number() Over (Order By (Select Null)),A.[StartDate])
From master..spt_values n1,master..spt_values n2
) B
返回
ID Date
1 2019-01-01
1 2019-01-02
1 2019-01-03
1 2019-01-04
1 2019-01-05
1 2019-01-06
1 2019-01-07
1 2019-01-08
1 2019-01-09
1 2019-01-15
2 2019-01-10
2 2019-01-11
....
5 2020-05-01
5 2020-05-02
5 2020-05-03
5 2020-05-04