sql >> Database >  >> RDS >> Sqlserver

Hoe minuutintervallen tussen twee datums in T-SQL genereren?

U kunt recursieve zoekopdrachten als volgt gebruiken:

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. PostgreSQL 9.1 primaire sleutel auto-increment

  2. Entity Framework met MySql en migraties mislukt omdat de maximale sleutellengte 767 bytes is

  3. Lijst met mooie permalinks en posttitel exporteren

  4. SQL-resultatentabel, match in tweede tabel SET-type