例如
有这么一张表 XATXDAY_FLIGHT(航班飞航表),
有这么一个字段 STD_LOCAL(起飞时间),
要求:统计一天24小时之内每隔10分钟,这10分钟之内有几架飞机起飞。
比如:XATXDAY_FLIGHT 表
STD_LOCAL . . .(其他字段省略)
12:00
12:05
12:10
12:20
12:25
.
.
.
(其他时间省略)
也就是说,结果应该是这样的:表示12:00~12:10这个时间段内有2架飞机起飞
12:00~12:10 2
12:10~12:20 1
12:20~12:30 2
查询语句如下:(相当与计算以10分钟分组的行数)
SELECT count(*) as total,t as 时间段
from(
SELECT STD_LOCAL ,
CASE FLOOR((TO_CHAR(TO_DATE(STD_LOCAL,‘HH24:MI‘),‘MI‘))/10)
WHEN 0 THEN ‘0‘
WHEN 1 THEN ‘1‘
WHEN 2 THEN ‘2‘
WHEN 3 THEN ‘3‘
WHEN 4 THEN ‘4‘
WHEN 5 THEN ‘5‘
END as T
FROM XATXDAY_FLIGHT
) temp
where to_char(sysdate,‘dd‘) = to_char(to_date(STD_LOCAL,‘yyyy-mm-dd hh24:mi:ss‘),‘dd‘)--只展示当天
GROUP BY TO_CHAR(TO_DATE(temp.STD_LOCAL,‘HH24:MI‘),‘HH24‘),temp.T
order by TO_CHAR(TO_DATE(temp.STD_LOCAL,‘HH24:MI‘),‘HH24‘),temp.T