你有不规则的时间段(有些是15分钟的长度,其他的是1小时的长度,其他的是几个小时的长度)。在这种情况下,你能做的最好的运行与case语句的查询:
with thetable as
(
SELECT 'TM' code, convert(datetime, '2011-04-15 07:01:00 AM') date, 1 id union all
SELECT 'TM', convert(datetime, '2011-04-15 07:05:00 AM'), 2 union all
SELECT 'TM', convert(datetime, '2011-04-15 07:08:00 AM'), 3 union all
SELECT 'TM', convert(datetime, '2011-04-15 07:20:00 AM'), 4 union all
SELECT 'TM', convert(datetime, '2011-04-15 08:25:00 AM'), 5
)
SELECT '07:00 - 07:15' interval, sum(case when CONVERT(varchar, date, 108) between '07:00:00' AND '07:14:59' then 1 else 0 end) counting
FROM thetable
union
select '07:15 - 08:00', sum(case when CONVERT(varchar, date, 108) between '07:15:00' AND '07:59:59' then 1 else 0 end)
from thetable
union
select '08:00 - 09:00', sum(case when CONVERT(varchar, date, 108) between '07:59:59' AND '08:59:59' then 1 else 0 end)
from thetable
现在,如果你确实有定期,你会做这样的事情:
select counting,
dateadd(ms,500-((datepart(ms,interval)+500)%1000),interval) intini
from
(
SELECT COUNT(1) counting, CONVERT(datetime, round(floor(CONVERT(float, date) * 24 * 4)/(24 * 4), 11)) interval
FROM
(
SELECT 'TM' code, convert(datetime, '2011-04-15 07:01:00 AM') date, 1 id union all
SELECT 'TM', convert(datetime, '2011-04-15 07:05:00 AM'), 2 union all
SELECT 'TM', convert(datetime, '2011-04-15 07:08:00 AM'), 3 union all
SELECT 'TM', convert(datetime, '2011-04-15 07:20:00 AM'), 4 union all
SELECT 'TM', convert(datetime, '2011-04-15 08:25:00 AM'), 5
) thetable
group by FLOOR(CONVERT(float, date) * 24 * 4)
) thetable2
注意24 * 4是15分钟的时间间隔。如果你的间隔时间是1小时,你应该用24代替。如果你的间隔时间是10分钟,那应该是24 * 6。我认为你得到了这张照片。
这是不是多余的: datepart(mi,DateTimeColumn)/ @interval * @interval 如果按区间划分,然后按时间划分,那么您实际上留下的是开头的东西吗? – Dhiren 2011-04-15 14:48:53
@DHiren :如果它是整数除法,并且小数被截断;本质上它变成了一个周期性的Floor()函数,你不会提到哪个Sybase数据库,但是在ASE SELECT 7/5 * 5中返回5,因为7/5部分被截断为1,因为它被转换为整数。 – Terry 2011-04-15 16:11:37
@Terry:这几乎是我所需要的,除非它不产生滚动的总和,但我可以在代码后面做到这一点,谢谢! – Dhiren 2011-04-15 16:34:55