专业编程基础技术教程

网站首页 > 基础教程 正文

SQL学习:SQL同比分析案例讲解,一看就懂

ccvgpt 2024-08-04 12:23:57 基础教程 11 ℃

在SQL数据统计分析中,经常用到数据的同比分析,本次给大家带来SQL数据分析中有关同比分析,涉及到SQL视图创建,SQL行转列,数据排序等访问知识,适用于初学者,每步都进行了注释,下面通过实例进行演示:

以下数据语句在oracle 数据库中正常使用,其他数据库请自测。

SQL学习:SQL同比分析案例讲解,一看就懂

案例:在销售合同中,需要统计同比分析,将今年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。

Tags:

最近发表
标签列表