在SQL数据统计分析中,经常用到数据的同比分析,本次给大家带来SQL数据分析中有关同比分析,涉及到SQL视图创建,SQL行转列,数据排序等访问知识,适用于初学者,每步都进行了注释,下面通过实例进行演示:
以下数据语句在oracle 数据库中正常使用,其他数据库请自测。
案例:在销售合同中,需要统计同比分析,将今年1月份的销售合同额同去年1月份的销售额进行对比。
原始数据如下:
想要的结果如下:
第一步:创建一个视图(目的便于后期引用或修改),筛选出2020年、2021年销售数据)
create view viewfinx_huanbi_fld as
SELECT f.合同签订年度,f.合同签订月份, SUM(f.合同金额) 销售额
FROM viewfinx_huanbi f
where f.合同签订年度 is not null and f.合同签订年度 in(2020,2021)
GROUP BY f.合同签订年度 , f.合同签订月份
结果如下:
第二步:再上一个视图基础上再创建一个视图,对数据进行处理,行转列处理,结果如下:
create view viewfinx_huanbi_fld1 as
select d.合同签订月份,
max(case d.合同签订年度 when '2020' then d.销售额 else 0 end ) as N2020年,
max(case d.合同签订年度 when '2021' then d.销售额 else 0 end ) as N2021年
from viewfinx_huanbi_fld d
group by d.合同签订月份
order by d.合同签订月份
第三步:引用第二步中的视图,进行数据分析,
select h.合同签订月份,
h.N2020年 ,
h.N2021年 ,
CASE WHEN h.N2021年>0 THEN CONCAT(ROUND(h.N2021年-h.N2020年)/h.N2021年*100,'%')
ELSE '同期没有数据' END 同比
from viewfinx_huanbi_fld1 h
结果如下:(未进行小数位数处理,大家在用的时候可以自行处理)
PS:在数据库中,通过起表起别名,便于显示出表列名,oracle数据库中日期转换函数:
substr(TO_CHAR(date, 'YYYYMMDD'), 1, 4) --日期转为年度函数,
TO_CHAR(date, 'mm') 合同签订月份,-- 日期转月份函数
TO_CHAR(date, 'q') 合同签订季度, ----日期转季度函数
您学会了吗,关注我,一起学SQL。