これを一般的に行う方法を次に示します。特定の日の 15 分間の内訳を提供します。
DECLARE @requests TABLE(requestTime DATETIME, NumberOfSessions INT);
INSERT @requests SELECT '20120605 23:59', 2
UNION ALL SELECT '20120606 00:00', 500
UNION ALL SELECT '20120606 00:07', 400
UNION ALL SELECT '20120606 00:17', 300
UNION ALL SELECT '20120606 23:57', 500
UNION ALL SELECT '20120607 00:00', 100;
DECLARE @day SMALLDATETIME; -- this would be a stored procedure parameter
SET @day = '20120606';
;WITH n AS
(
SELECT TOP 96 n = DATEADD(MINUTE, 15*
(ROW_NUMBER() OVER (ORDER BY [object_id])-1), @day)
FROM sys.all_columns ORDER BY [object_id]
)
SELECT requestTime = n.n, SumNumberOfSessions = COALESCE(SUM(NumberOfSessions), 0)
FROM n LEFT OUTER JOIN @requests AS r
ON r.requestTime >= n
AND r.requestTime < DATEADD(MINUTE, 15, n)
GROUP BY n.n
ORDER BY requestTime;
結果:
requestTime SumNumberOfSessions
----------------------- -------------------
2012-06-06 00:00:00.000 900
2012-06-06 00:15:00.000 300
2012-06-06 00:30:00.000 0
...
2012-06-06 23:30:00.000 0
2012-06-06 23:45:00.000 500