码迷,mamicode.com
首页 > 数据库 > 详细

oracle按每个10分钟进行分组展示数据

时间:2018-03-07 21:43:40      阅读:1554      评论:0      收藏:0      [点我收藏+]

标签:rom   floor   log   end   char   ora   oca   字段   cal   

例如

有这么一张表 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

oracle按每个10分钟进行分组展示数据

标签:rom   floor   log   end   char   ora   oca   字段   cal   

原文地址:https://www.cnblogs.com/nizuimeiabc1/p/8525010.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!