网站首页 > 技术文章 正文
在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。
- 上一篇: 打卡 SQL九月学习总结
- 下一篇: 通过 SQL 训练机器学习模型的引擎
猜你喜欢
- 2025-06-13 Windows安装PostgreSQL、PostGIS数据库
- 2025-06-13 4.直方图介绍和使用|MySQL索引学习
- 2025-06-13 SQLServer 学习笔记1 安装SQLServer2016数据库引擎
- 2025-06-13 学会Sqlserver更应该来学习Azure,对照Sqlserver学Azure
- 2025-06-13 初学者程序员要学好.Net,只要学习这几个框架就够了
- 2025-06-13 谈谈该如何学好《My SQL数据库应用案例教程》这门课程
- 2025-06-13 零基础入门开始学习SQL Server的字符串类型
- 2025-06-13 GitHub标星65K,这套万人期待的 SQL 成神之路PDF,重磅开源分享!
- 2025-06-13 SQL 基础学习更新和删除(十四)
- 2025-06-13 从Sql角度,对比学习Python数据处理包pandas
- 最近发表
- 标签列表
-
- axure 注册码 (25)
- exploit db (21)
- mutex_lock (30)
- oracleclient (27)
- think in java (14)
- javascript权威指南 (19)
- nfs (25)
- componentart (17)
- yii框架 (14)
- springbatch (28)
- oracle数据库备份 (25)
- iptables (21)
- 自动化单元测试 (18)
- python编写软件 (14)
- dir (26)
- connectionstring属性尚未初始化 (23)
- output (32)
- panel滚动条 (28)
- centos 5 4 (23)
- sql学习 (33)
- dfn (14)
- http error 503 (21)
- pop3服务器 (18)
- 图表组件 (17)
- android退出应用 (21)