Oracle地铁OD全网15分钟净客流统计SQL
2018-03-05 14:26
295 查看
原始数据:
/*15分钟客流统计*/
with tb as(
--使用正则表达式拼接格式化时间17:17:52为2018/1/1 17:52:00 date类型
select t.*,
to_date(regexp_substr(t.进站时间, '[^:]+', 1, 2) || ':' ||regexp_substr(t.进站时间, '[^:]+', 1, 3) || ':00', 'hh24:mi:ss') as 进站时间戳,
to_date(regexp_substr(t.出站时间, '[^:]+', 1, 2) || ':' ||regexp_substr(t.出站时间, '[^:]+', 1, 3) || ':00', 'hh24:mi:ss') as 出站时间戳
from cq_dt_in_ext_table1 t
),
tb1 as(
--对刷卡进站时间每15分钟分组
select gp, count(*) as in_cnt
from (select t.进站时间戳,
trunc(t.进站时间戳, 'mi') - mod(to_char(进站时间戳, 'mi'), 15) / 24 / 60 as gp,
t.卡号,
t.进站编码
from tb t)
group by gp
),
tb2 as
--对刷卡出站时间每15分钟分组
(select gp, count(*) as out_cnt
from (select t.出站时间戳,trunc(t.出站时间戳, 'mi') -mod(to_char(出站时间戳, 'mi'), 15) / 24 / 60 as gp,
t.卡号,
t.出站编码
from tb t)
group by gp
),
tb3 as(
--构造5-24点每15分钟时间码表
select to_date(to_char(to_date('05:00:00', 'hh24:mi:ss') +level * 15 / 24 / 60,'hh24:mi:ss'),'hh24:mi:ss') as consult_time
from dual
connect by level <= 76
),
tb4 as(
select t3.consult_time,
coalesce(t1.in_cnt, 0) in_cnt,
coalesce(t2.out_cnt, 0) out_cnt,
'全网' as in_line
from tb3 t3
left join tb1 t1 on t3.consult_time = t1.gp
left join tb2 t2 on t3.consult_time = t2.gp
)
select t.consult_time 当前时间,
sum(t.in_cnt) over(order by consult_time) - sum(t.out_cnt) over(order by consult_time) 净客流,
t.in_line 线路
from tb4 t;查询结果:
/*15分钟客流统计*/
with tb as(
--使用正则表达式拼接格式化时间17:17:52为2018/1/1 17:52:00 date类型
select t.*,
to_date(regexp_substr(t.进站时间, '[^:]+', 1, 2) || ':' ||regexp_substr(t.进站时间, '[^:]+', 1, 3) || ':00', 'hh24:mi:ss') as 进站时间戳,
to_date(regexp_substr(t.出站时间, '[^:]+', 1, 2) || ':' ||regexp_substr(t.出站时间, '[^:]+', 1, 3) || ':00', 'hh24:mi:ss') as 出站时间戳
from cq_dt_in_ext_table1 t
),
tb1 as(
--对刷卡进站时间每15分钟分组
select gp, count(*) as in_cnt
from (select t.进站时间戳,
trunc(t.进站时间戳, 'mi') - mod(to_char(进站时间戳, 'mi'), 15) / 24 / 60 as gp,
t.卡号,
t.进站编码
from tb t)
group by gp
),
tb2 as
--对刷卡出站时间每15分钟分组
(select gp, count(*) as out_cnt
from (select t.出站时间戳,trunc(t.出站时间戳, 'mi') -mod(to_char(出站时间戳, 'mi'), 15) / 24 / 60 as gp,
t.卡号,
t.出站编码
from tb t)
group by gp
),
tb3 as(
--构造5-24点每15分钟时间码表
select to_date(to_char(to_date('05:00:00', 'hh24:mi:ss') +level * 15 / 24 / 60,'hh24:mi:ss'),'hh24:mi:ss') as consult_time
from dual
connect by level <= 76
),
tb4 as(
select t3.consult_time,
coalesce(t1.in_cnt, 0) in_cnt,
coalesce(t2.out_cnt, 0) out_cnt,
'全网' as in_line
from tb3 t3
left join tb1 t1 on t3.consult_time = t1.gp
left join tb2 t2 on t3.consult_time = t2.gp
)
select t.consult_time 当前时间,
sum(t.in_cnt) over(order by consult_time) - sum(t.out_cnt) over(order by consult_time) 净客流,
t.in_line 线路
from tb4 t;查询结果:
相关文章推荐
- oracle一条sql语句统计充值表中今天,昨天,前天三天充值记录
- oracle分组统计sql
- oracle的按月统计sql(一个数据库面试题)
- oracle查看sql执行计划和统计信息
- 【SQL两表关联级联】两张表关联,统计级联数量ORACLE
- ORACLE SQL调优之统计信息缺失导致的逻辑读暴增
- Oracle - SQL 优化 -------- > SET AUTOTRACE 中Statistics(统计信息)说明
- Oracle SQL ratio_to_report函数、占比统计
- 网点发展统计报表sql(oracle)
- ORACLE 统计正负个数sql
- Oracle按时间分组统计的sql与oracle 多行合并一行
- oracle sql语句执行时间统计sql trace
- [Oracle SQL] 使用rollup分组统计按统计结果分组排序显示的问题
- 渠道发展统计报表sql(oracle)
- 【ORACLE】一个简单实用的对数据进行行列转换并统计的SQL语句
- oracle之 v$sql_monitor 监视正在运行的SQL语句的统计信息
- 有时候执行的oracle,sql语句要查看下性能情况,可以用这个进行下简单计算和统计
- 一段oracle中的“复杂”分组统计sql
- oracle之 v$sql_monitor 监视正在运行的SQL语句的统计信息
- oracle 统计sql