sql >> Databasteknik >  >> RDS >> Sqlserver

Hur genererar man minutintervall mellan två datum i T-SQL?

Du kan använda rekursiv fråga så här :

declare @intervalMinutes int = 10
declare @myDates table (
myId int primary key identity,
startTime datetime,
endTime datetime
)

DECLARE @startTime DATETIME = '2016-07-10 08:00'
DECLARE @endTime DATETIME = '2016-07-10 09:00'

;WITH CTE AS
(
    SELECT  @startTime st
    UNION   ALL
    SELECT  dateadd(MINUTE,@intervalMinutes,st) st
    FROM    cte
    where   dateadd(MINUTE,@intervalMinutes,st) < @endTime
)
INSERT INTO @myDates(startTime,endTime)
SELECT st,dateadd(MINUTE,@intervalMinutes,st) FROM cte

SELECT  * FROm @myDates


  1. Returvärde för Oracle.DataAccess kör icke-fråga (lagrad proc)

  2. Hur får jag alla kombinationer av data från en MySQL-tabell?

  3. Multiplikationsaggregatoperator i SQL

  4. Python+MySQLdb konstigt problem