SQL-计算日期之间每天的总ID

时间:2020-03-27 15:16:21

标签: sql sql-server

这是我的数据的样子

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。

我不确定该怎么做。感谢所有帮助。

1 个答案:

答案 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