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

Få hver time for et tidsinterval

Ingen loops, rekursive CTE'er eller taltabel påkrævet.

DECLARE 
  @start TIME(0) = '11:00 AM', 
  @end   TIME(0) =  '2:00 PM';

WITH x(n) AS 
(
  SELECT TOP (DATEDIFF(HOUR, @start, @end) + 1) 
  rn = ROW_NUMBER() OVER (ORDER BY [object_id]) 
  FROM sys.all_columns ORDER BY [object_id]
)
SELECT t = DATEADD(HOUR, n-1, @start) FROM x ORDER BY t;


  1. Dvale Soft Slet ved hjælp af update Cascade

  2. Udarbejd primær nøglefejl på postgresql, heroku, Rails 4

  3. Fjernelse af overlapningstimer fra optællingen af ​​ikke-arbejdsdage

  4. TRIM() Funktion i Oracle