-6

我有一张表格,告诉我一件设备的开始和结束“预订日期”。我想创建并填充一个新表,填写所有“日期之间”以及特定项目的开始和结束日期。新表应包括以下列:

Item Name  conferencename  reserved dates
4

1 回答 1

0

我可能是唯一一个觉得这个问题很有趣的人(只是没有得到完美的解释)。

这是一个SQL Fiddle 演示,它显示了一种使用游标填充日期的方法。我相信您要求的脚本部分如下所示:

CREATE TABLE EquipmentLog 
    ([Item Name] varchar(255),
     conferencename varchar(255),
     [reserved dates] datetime);

DECLARE @Item_Name varchar(255),
        @conferencename varchar(255),
        @start_reserve_date datetime,
        @end_reserve_date datetime,
        @reserve_date datetime

DECLARE cur CURSOR FAST_FORWARD
FOR
SELECT * FROM EquipmentRegister

OPEN cur

FETCH NEXT FROM cur
INTO @Item_Name, @conferencename, @start_reserve_date, @end_reserve_date

WHILE (@@FETCH_STATUS=0)
BEGIN
    SET @reserve_date = @start_reserve_date
    WHILE (@reserve_date <= @end_reserve_date)
    BEGIN
        INSERT INTO EquipmentLog
        SELECT @Item_Name, @conferencename, @reserve_date

        SELECT @reserve_date = DATEADD(day, 1, @reserve_date)
    END

    FETCH NEXT FROM cur
    INTO @Item_Name, @conferencename, @start_reserve_date, @end_reserve_date
END

CLOSE cur
DEALLOCATE cur
于 2013-05-08T21:34:11.643 回答