我正在尝试创建我的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
答案 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