#sql-server #tsql
#sql-сервер #tsql
Вопрос:
У меня есть таблица в MSSQL, два столбца которой выглядят как приведенный ниже пример. Я хочу подсчитать количество строк, которые у меня есть за все часы во время сеанса.
Session Time Duration
2011-06-09 23:47:07 00:01:51
2011-06-09 23:54:45 00:12:37
2011-06-09 23:41:17 00:21:57
2011-06-09 23:41:54 00:34:35
2011-06-09 22:47:51 00:01:20
2011-06-09 22:56:04 00:09:33
2011-06-09 22:55:40 00:11:08
2011-06-09 22:47:30 00:05:06
В итоге результат выглядел бы примерно так:
Session Time Number of Records
2011-06-09 23:00:00 4
2011-06-09 22:00:00 4
Ответ №1:
-- Test data
;with YourTable([Session Time]) as
(
select cast('2011-06-09 23:47:07' as datetime) union all
select '2011-06-09 23:54:45' union all
select '2011-06-09 23:41:17' union all
select '2011-06-09 23:41:54' union all
select '2011-06-09 22:47:51' union all
select '2011-06-09 22:56:04' union all
select '2011-06-09 22:55:40' union all
select '2011-06-09 22:47:30'
)
-- Query
select dateadd(hh, datediff(hh, 0, [Session Time]), 0) as [Session Time],
count(*) as [Number of Records]
from YourTable
group by dateadd(hh, datediff(hh, 0, [Session Time]), 0)
Комментарии:
1. Потрясающе! Это именно то, что я искал, я просто добавил
ORDER BY [Session Time]
в конце запроса для сортировки от даты начала до даты окончания.
Ответ №2:
это может помочь
declare @tbl table
(
RangeCount int,
TimeRange INT
)
insert into @tbl (TimeRange) values (0)
insert into @tbl (TimeRange) values (1)
insert into @tbl (TimeRange) values (2)
insert into @tbl (TimeRange) values (3)
insert into @tbl (TimeRange) values (4)
insert into @tbl (TimeRange) values (5)
insert into @tbl (TimeRange) values (6)
insert into @tbl (TimeRange) values (7)
insert into @tbl (TimeRange) values (8)
insert into @tbl (TimeRange) values (9)
insert into @tbl (TimeRange) values (10)
insert into @tbl (TimeRange) values (11)
insert into @tbl (TimeRange) values (12)
insert into @tbl (TimeRange) values (13)
insert into @tbl (TimeRange) values (14)
insert into @tbl (TimeRange) values (15)
insert into @tbl (TimeRange) values (16)
insert into @tbl (TimeRange) values (17)
insert into @tbl (TimeRange) values (18)
insert into @tbl (TimeRange) values (19)
insert into @tbl (TimeRange) values (20)
insert into @tbl (TimeRange) values (21)
insert into @tbl (TimeRange) values (22)
insert into @tbl (TimeRange) values (23)
insert into @tbl (
RangeCount,
TimeRange)
select count(1), datediff(hh,GETDATE(),SessionTime)
from tablename (NOLOCK)
group by datediff(hh,GETDATE(),SessionTime)
select SUM(ISNULL(RangeCount, 0))as TotalCount,
CASE TimeRange
WHEN 0 THEN '00:00 - 01:00'
WHEN 1 THEN '01:00 - 02:00'
WHEN 2 THEN '02:00 - 03:00'
WHEN 3 THEN '03:00 - 04:00'
WHEN 4 THEN '04:00 - 05:00'
WHEN 5 THEN '05:00 - 06:00'
WHEN 6 THEN '06:00 - 07:00'
WHEN 7 THEN '07:00 - 08:00'
WHEN 8 THEN '08:00 - 09:00'
WHEN 9 THEN '09:00 - 10:00'
WHEN 10 THEN '10:00 - 11:00'
WHEN 11 THEN '11:00 - 12:00'
WHEN 12 THEN '12:00 - 13:00'
WHEN 13 THEN '13:00 - 14:00'
WHEN 14 THEN '14:00 - 15:00'
WHEN 15 THEN '15:00 - 16:00'
WHEN 16 THEN '16:00 - 17:00'
WHEN 17 THEN '17:00 - 18:00'
WHEN 18 THEN '18:00 - 19:00'
WHEN 19 THEN '19:00 - 20:00'
WHEN 20 THEN '20:00 - 21:00'
WHEN 21 THEN '21:00 - 22:00'
WHEN 22 THEN '22:00 - 23:00'
WHEN 23 THEN '23:00 - 24:00'
END AS TimeRange
from @tbl
group by TimeRange