Microsoft SQL Server 中存在一个表,其中包含记录 ID、开始日期、结束日期和数量。
这个想法是,对于每条记录,数量/范围内的总天数 = 每日数量。
鉴于存在包含所有可能日期的表,如何在 SQL Server 中生成类似于以下示例的结果集?
前任:
RecordID | Start Date | End Date | Quantity
1 | 1/1/2010 | 1/5/2010 | 30000
2 | 1/3/2010 | 1/9/2010 | 20000
3 | 1/1/2010 | 1/7/2010 | 10000
Results as
1 | 1/1/2010 | QTY (I can do the math easy, just need the dates view)
1 | 1/2/2010 |
1 | 1/3/2010 |
1 | 1/4/2010 |
1 | 1/3/2010 |
2 | 1/4/2010 |
2 | 1/5/2010 |
2 | 1/6/2010 |
2 | 1/7/2010 |
2 | 1/8/2010 |
2 | 1/9/2010 |
3 | 1/1/2010 |
3 | 1/2/2010 |
3 | 1/3/2010 |
3 | 1/4/2010 |
3 | 1/5/2010 |
3 | 1/6/2010 |
3 | 1/7/2010 |
按我可以得到的日期分组,然后得到当天的数量总和,但是由于用户提供的过滤器可能会排除其中一些记录,因此最终结果集无法汇总。
编辑
澄清一下,这只是一个示例。过滤器无关紧要,因为我可以加入到一边以在结果中提取与记录 ID 相关的详细信息。
真实数据包含 N 条记录,每周增加,日期永远不会相同。可能有 2000 条记录具有不同的开始日期和结束日期......这就是我要为其生成视图的内容。我可以正确加入数据以完成我需要的其余工作
我还应该提到这是针对过去、现在和未来的数据。我很想摆脱一个临时的日期表。我正在使用递归查询来获取 50 年内存在的所有日期,但这超出了我无法使用的视图的 MAXRECURSION 限制。