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

Posted ppjj

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle按每个10分钟进行分组展示数据相关的知识,希望对你有一定的参考价值。

例如

有这么一张表 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分钟进行分组展示数据的主要内容,如果未能解决你的问题,请参考以下文章

在 Oracle SQL 中按时间间隔聚合数据

按 10 分钟间隔对 pandas DataFrame 进行分组[重复]

SQL (Oracle):按特定列分组

如何使用熊猫按 10 分钟对时间序列进行分组

Oracle数据库按时间进行分组统计数据的方法

按 15 分钟间隔对 mysql 查询进行分组