sql >> Database teknologi >  >> RDS >> Sqlserver

Hvordan genererer man minutintervaller mellem to datoer i T-SQL?

Du kan bruge rekursiv forespørgsel som denne :

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. Hvordan sender man en tabel eller rækker til en funktion i Postgresql?

  2. Skub delvise resultatdata i array og send

  3. Konvertering af en oracle-forespørgsel til MySQL-forespørgsel

  4. INDSÆT ved hjælp af LIST i Stored Procedure