我使用udf在飛行中創建日期範圍。
Select Year=Year(RetVal)
,Month=Month(RetVal)
,Week=DatePart(WEEK,RetVal)
,Day=Day(RetVal)
,Hour=DatePart(HH,RetVal)
,Min=DatePart(MI,RetVal)
From [dbo].[udf-Create-Range-Date]('2016-01-01','2016-01-02','MI',1)
返回
Year Month Week Day Hour Min
2016 1 1 1 0 0
2016 1 1 1 0 1
2016 1 1 1 0 2
2016 1 1 1 0 3
2016 1 1 1 0 4
2016 1 1 1 0 5
2016 1 1 1 0 6
2016 1 1 1 0 7
2016 1 1 1 0 8
2016 1 1 1 0 9
...
下面是函數
CREATE FUNCTION [dbo].[udf-Create-Range-Date] (@DateFrom datetime,@DateTo datetime,@DatePart varchar(10),@Incr int)
Returns
@ReturnVal Table (RetVal datetime)
As
Begin
With DateTable As (
Select DateFrom = @DateFrom
Union All
Select Case @DatePart
When 'YY' then DateAdd(YY, @Incr, df.dateFrom)
When 'QQ' then DateAdd(QQ, @Incr, df.dateFrom)
When 'MM' then DateAdd(MM, @Incr, df.dateFrom)
When 'WK' then DateAdd(WK, @Incr, df.dateFrom)
When 'DD' then DateAdd(DD, @Incr, df.dateFrom)
When 'HH' then DateAdd(HH, @Incr, df.dateFrom)
When 'MI' then DateAdd(MI, @Incr, df.dateFrom)
When 'SS' then DateAdd(SS, @Incr, df.dateFrom)
End
From DateTable DF
Where DF.DateFrom < @DateTo
)
Insert into @ReturnVal(RetVal) Select DateFrom From DateTable option (maxrecursion 32767)
Return
End
-- Syntax Select * from [dbo].[udf-Create-Range-Date]('2016-10-01','2020-10-01','YY',1)
-- Syntax Select * from [dbo].[udf-Create-Range-Date]('2016-10-01','2020-10-01','DD',1)
-- Syntax Select * from [dbo].[udf-Create-Range-Date]('2016-10-01','2016-10-31','MI',15)
-- Syntax Select * from [dbo].[udf-Create-Range-Date]('2016-10-01','2016-10-02','SS',1)
在線搜索'sql server create date time table' – sagi