如何在SQL中声明日期多值

时间:2016-09-23 15:43:27

标签: sql-server tsql declare

我正在尝试创建我的SQL语法,以便我们可以拥有多种输入。我想出了如何在一个设定的日期做它并且它起作用了。 我的同步是:

DECLARE @MyDay AS VARCHAR(50);
DECLARE @NextDay AS VARCHAR(50);

SET @MyDay = '8/30/2016';
SET @NextDay = DATEADD(d, 1, @MyDay);

然而,我一直坚持如何在多个日期做到这一点。理想情况下,我想放入一个日期范围,并从中扫描记录,即设置在10月1日到10月10日之间的范围。

我正在使用SQL Server Management Studio 2008

1 个答案:

答案 0 :(得分:0)

如果你只想要在8/30/16和9/5/16之间的一系列日子和次日,你可以使用如下的派生表方法。

declare @n int;
declare @StartDate datetime, @EndDate datetime;

set @n = 5;
set @StartDate = '20160830';
set @EndDate = dateadd(day, @n, @StartDate);

select cast(dateadd(day, number, @StartDate) as date) as MyDate,
 cast(dateadd(day, number + 1, @StartDate) as date) as MyNextDate
from 
    (select distinct number from master.dbo.spt_values
     where name is null
    ) n
where dateadd(day, number, @StartDate) < @EndDate;

或者,您可以使用临时表,表变量来存储日期,也可以使用cte。

下面给出了递归cte imlementation示例。请注意,如果您有一个较长的日期范围,则需要设置MAXRECURSION选项,因为默认最大递归为100。

declare @n int;
declare @StartDate datetime, @EndDate datetime;

set @n = 5;
set @StartDate = '20160830';
set @EndDate = dateadd(day, @n, @StartDate);

 ;with DateSeq as
 (
 select cast(@StartDate as date) as MyDate
 union all
 select dateadd(day , 1, MyDate) AS MyDate
    from DateSeq where dateadd (day, 1, MyDate) < @EndDate
 )
select MyDate, dateadd(day , 1, MyDate) AS NextDate
 from DateSeq;

临时表实现示例如下。

declare @MyDateRange table(MyDate date);

 Insert into @MyDateRange values('8/30/2016')
 Insert into @MyDateRange values('9/1/2016')
 Insert into @MyDateRange values('9/2/2016')
 Insert into @MyDateRange values('9/3/2016')
 Insert into @MyDateRange values('9/4/2016')

select MyDate, dateadd(day, 1, MyDate) as NextDate from @MyDateRange