生成连续日期的sql临时表到左外连接到

时间:2011-01-19 15:52:32

标签: sql sql-server-2005

我有一个数据表,我想通过存储过程选择,这样用户可以将MS excel前端连接到它,并使用原始数据作为图形来源。

表的原始数据的问题是日期中存在间隙,因为如果给定日期没有数据(没有该日期的记录),那么当用户尝试绘制它时会产生问题。

我想要将我的存储过程更新到左外连接到一个临时表的日期,以便右侧将作为空值进入,我可以转换为零,以便他们有一个简单的绘图经验。

如何在开始日期和结束日期之间最好地生成一个日期字段表?

3 个答案:

答案 0 :(得分:13)

在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并返回结果。

答案 1 :(得分:5)

另一种方法是使用内存表。由于上述某些解决方案的递归限制,它不会窒息。

DECLARE @dates AS TABLE ([Date] date);

DECLARE @date date = {d '2010-10-01'};
DECLARE @endDate date = {d '2010-11-01'};

while (@date < @endDate)
BEGIN
    INSERT INTO @dates VALUES (@date);
    SET @date = dateadd(DAY, 1, @date)
END
SELECT * FROM @dates;

SQL Fiddle

答案 2 :(得分:4)

CTE的一种方式是:

with cte_dates as (
  select cast('20110119' as datetime) as [date]
  union all
  select dateadd(dd, 1, [date])
      from cte_dates
      where dateadd(dd, 1, [date]) <= '20111231'
)
select [date], YourColumn
    from cte_dates
        left join YourTable
            on ...
option (maxrecursion 0);