本文主要向大家介绍了Oracle数据库之oracle按每个10分钟进行分组展示数据,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助。
例如
有这么一张表 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