文章目录
09:服务域:安装主题分析实现
-
目标:掌握安装主题的需求分析及实现
-
路径
- step1:需求
- step2:分析
- step3:实现
-
实施
- 需求:统计不同维度下的安装主题指标的结果
-
分析
-
指标:安装数量、支付金额
-
维度
- 安装方式
- 日期维度:天、周、月
- 油站维度:类型、省份、城市、地区
- 客户维度:类型、省份
-
数据
-
事实表
- fact_srv_install:安装事务事实表
select inst_id, --安装单id inst_type_id, --安装方式id 1-设备安装,2-设备联调 exp_device_money, --安装费用 dt,--日期 os_id --油站id from one_make_dwb.fact_srv_install;
-
-
维度表
- dim_oilstation:油站维度表
select id,--油站id company_name,--公司名称 province_name,--省份名称 city_name,--城市名称 county_name,--区域名称 customer_classify_name,--客户名称 customer_province_name--客户省份 from dim_oilstation;
+ dim\_date:时间维度表 ``` select date_id,--天 week_in_year_id,--周 year_month_id --月 from dim_date; ``` ![image-20211013104333958](https://img-blog.csdnimg.cn/img_convert/f1e91fbae0463c2053d47c99b989616a.png)
-
-
实现
- 建表
create table if not exists one_make_st.subj_install( install_way string comment '安装方式' ,install_sum bigint comment '安装数量' ,sum_money int comment '支付费用' ,dws_day string comment '日期维度-按天' ,dws_week string comment '日期维度-按周' ,dws_month string comment '日期维度-按月' ,oil_type string comment '油站维度-油站类型' ,oil_province string comment '油站维度-油站所属省' ,oil_city string comment '油站维度-油站所属市' ,oil_county string comment '油站维度-油站所属区' ,customer_classify string comment '客户维度-客户类型' ,customer_province string comment '客户维度-客户所属省' ) comment '安装主题表' partitioned by (month string, week string, day string) stored as orc location '/data/dw/st/one\_make/subj\_install';
-
构建
insert overwrite table one_make_st.subj_install partition(month = '202101', week='2021W1', day='20210101')
select
--安装方式
max(case when install.inst_type_id = 1 then '设备安装' when install.inst_type_id = 2 then '设备联调' else '未知' end) install_way
, count(install.inst_id) install_sum --安装数量
, sum(install.exp_device_money) sum_money --支付金额
, dd.date_id dws_day --日期天
, dd.week_in_year_id dws_week --日期周
, dd.year_month_id dws_month --日期月
, dimoil.company_name oil_type --油站类型
, dimoil.province_name oil_province --油站省份
, dimoil.city_name oil_city --油站城市
, dimoil.county_name oil_county --油站地区
, dimoil.customer_classify_name customer_classify --客户类型
, dimoil.customer_province_name customer_province --客户省份
--安装事务事实表
from one_make_dwb.fact_srv_install install
--关联日期维度表
left join one_make_dws.dim_date dd on install.dt = dd.date_id
--关联油站维度表
left join one_make_dws.dim_oilstation dimoil on install.os_id = dimoil.id
where dd.year_month_id = '202101' and dd.week_in_year_id = '2021W1' and dd.date_id = '20210101'
--按照维度分组
group by
inst_type_id,
dd.date_id, dd.week_in_year_id, dd.year_month_id,
dimoil.company_name, dimoil.province_name, dimoil.city_name, dimoil.county_name,
dimoil.customer_classify_name, dimoil.customer_province_name
;
-
小结
- 掌握安装主题的需求分析及实现
10:服务域:维修主题分析实现
-
目标:掌握维修主题的需求分析及实现
-
路径
- step1:需求
- step2:分析
- step3:实现
-
实施
- 需求:统计不同维度下的维修主题指标的结果
-
分析
-
指标
- 支付费用、工时费用、零部件费用、交通费用
- 故障总数、最大数量、平均数量
-
维度
- 日期维度:天、周、月
- 油站维度:类型、省份、城市、地区
- 客户维度:类型、省份
- 物流公司
-
数据
-
事实表
- fact_srv_repair:维修事务事实表
select hour_money,--工时费用 parts_money,--配件物料费用 fars_money,--交通费用 fault_type_ids, --故障id集合 dt,--日期 os_id,--油站id ss_id --服务网点id from fact_srv_repair;
-
fact_srv_stn_ma:网点物料事务事实表
-
-
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!