我有一个数据表,我想通过存储过程选择出来,这样用户可以将MS excel前端连接到它,并使用原始数据作为图形来源.
表的原始数据的问题是日期中存在间隙,因为如果给定日期没有数据(没有该日期的记录),那么当用户尝试绘制它时会产生问题.
我想要将我的存储过程更新到左外连接到临时表的日期,以便右侧将作为空值进入,我可以转换为零,以便他们具有简单的绘图体验.
如何在开始日期和结束日期之间最好地生成一个日期字段表?
解决方法
在sql Server 2005及更高版本中,您可以使用类似这样的内容(公用表表达式CTE)来执行此操作:
DECLARE @DateFrom DATETIME SET @DateFrom = '2011-01-01' DECLARE @DateTo DATETIME SET @DateTo = '2011-01-10' ;WITH DateRanges AS ( SELECT @DateFrom AS 'DateValue' UNION ALL SELECT DATEADD(DAY,1,DateValue) FROM DateRanges WHERE DateValue < @DateTo ) SELECT * FROM DateRanges
你可以LEFT OUTER JOIN这个CTE对你的表并返回结果.