sql计算周月同比

本文介绍了三种计算周月同比的SQL方法。方法一适用于全量表,利用自关联进行笛卡尔积操作;方法二针对大数据场景,如Hive中的增量表,通过扫描单天分区计算;方法三则涉及关联时间维度表来实现同比计算。
摘要由CSDN通过智能技术生成

方法一 :当面对全量表,使用自关联 --笛卡尔积
先看一下笛卡尔积的结果

首先看一下全量表的明细数据
在这里插入图片描述

对明细数据进行聚合
在这里插入图片描述

select
*
from
(    select count(*) as cnt,app_id,down_date
     from dwd_hispace_down_ds 
     group by app_id,down_date) a
left join
(    select count(*) as cnt,app_id,down_date
     from dwd_hispace_down_ds 
     group by app_id,down_date) b
on a.app_id=b.app_id

在这里插入图片描述

select
a.down_date
,a.app_id
,sum(case when a.down_date - b.down_date=7 
 then a.cnt/b.cnt else 0 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值