sql >> Databasteknik >  >> RDS >> Sqlserver

Få varje timme för ett tidsintervall

Inga loopar, rekursiva CTE:er eller taltabeller krävs.

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. Topp 'n' resultat för varje sökord

  2. MySQL MIN() och MAX() med LIMIT

  3. Django ORM lämnar lediga anslutningar på Postgres DB

  4. PG::Fel:SELECT DISTINCT, ORDER BY-uttryck måste visas i urvalslistan