环比、环比增长率、同比、同比增长率 ,占比,Mysql 8.0 实例(最简单的方法之一)(sample database classicmodels _No.2

准备工作

可以去下载 classicmodels 数据库资源如下

[ 点击:classicmodels官网下载]

[也可以去CSDN 去免费资源下载]

如果是 mysql 5.7就不支持

前言

先说下,什么是 环比、环比增长率、同比、同比增长率,根据百度百科上的 说明:

环比增长率 环比增长率,一般是指和上期相比较的增长率。 环比增长率=(本期的某个指标的值-上一期这个指标的值)/上一期这个指标的值*100%。 比如,2008年5月与2008年4月的环比增长是指总是以上一期为基期求的增长量(或率),一般会列一个表,把若干年的环比增长都列出来,进行分析比较。 如:98年净利环比增长量=98年净利-97年净利。 98年净利环比增长率=(98年净利/97年净利)-1=(98年净利-97年净利)/97年净利。

同比增长率 某个指标的同期比=(当年的某个指标的值-上年同期这个指标的值)/上年同期这个指标的值 即:同比增长率=(当年的指标值-上年同期的值)÷上年同期的值*100%

提示:以下是本篇文章正文内容,下面案例可供参考

一、每月销售额

Orders:存储客户下达的销售订单。 OrderDetails:存储销售订单。 orderdetails.priceEach -----单个价格 orderdetails.quantityOrdered----订购数量 销售额=priceEach *quantityOrdered

sql 复制代码
select DATE_FORMAT(orderdate,'%Y-%m')  as 'yyyy_mm',
sum(b.priceEach*b.quantityOrdered ) as 'sale_amount' 
from  classicmodels.orders a left join classicmodels.orderdetails b
on a.orderNumber =b.orderNumber 
group by DATE_FORMAT(orderdate,'%Y-%m')

图表

二、使用窗口函数LAG

1.环比,环比增长率

环比=本月销售额/上个月的销售额 环比增长率=(本月销售额-上个月的销售额)/上个月的销售额

sql 复制代码
select 
yyyy_mm as '年月',
ifnull(sale_amount,0) as '本月销售额',
lag(sale_amount) over (order by yyyy_mm) as '上个月的销售额',
ifnull(sale_amount,0)/lag(sale_amount) over (order by yyyy_mm)  *100 as '环比',
(ifnull(sale_amount,0)-lag(sale_amount) over (order by yyyy_mm))/lag(sale_amount) over (order by yyyy_mm) *100 as '环比增长率'
from (

select DATE_FORMAT(orderdate,'%Y-%m')  as 'yyyy_mm',
sum(b.priceEach*b.quantityOrdered ) as 'sale_amount' 
from  classicmodels.orders a left join classicmodels.orderdetails b
on a.orderNumber =b.orderNumber 
group by DATE_FORMAT(orderdate,'%Y-%m')

) a

2.同比,同比增长率

同比=本月销售额/上年同月的销售额 同比增长率=(本月销售额-上年同月的销售额)/上年同月的销售额

sql 复制代码
select 
yyyy_mm as '年月',
ifnull(sale_amount,0) as '本月销售额',
lag(sale_amount) over (order by yyyy_mm) as '上个月的销售额',
ifnull(sale_amount,0)/lag(sale_amount) over (order by yyyy_mm)  *100 as '销售额环比',
(ifnull(sale_amount,0)-lag(sale_amount) over (order by yyyy_mm))/lag(sale_amount) over (order by yyyy_mm) *100 as '销售额环比增长率',

lag(sale_amount,12) over (order by yyyy_mm) as '上年同期的销售额',
ifnull(sale_amount,0)/lag(sale_amount,12) over (order by yyyy_mm)  *100 as '销售额同比',
(ifnull(sale_amount,0)-lag(sale_amount,12) over (order by yyyy_mm))/lag(sale_amount,12) over (order by yyyy_mm) *100 as '销售额同比增长率'
from (
select DATE_FORMAT(orderdate,'%Y-%m')  as 'yyyy_mm',
sum(b.priceEach*b.quantityOrdered ) as 'sale_amount' 
from  classicmodels.orders a left join 
classicmodels.orderdetails b on a.orderNumber =b.orderNumber 
group by DATE_FORMAT(orderdate,'%Y-%m')) a

3.当年每月占比,当年每月累计占比

(partition by left(yyyy_mm,4) order by yyyy_mm ) 这个取前面4位 年份,就是根据 年份分组,然后再根据年月排序

sql 复制代码
select 
yyyy_mm as '年月',
ifnull(sale_amount,0) as '本月销售额',
sum(ifnull(sale_amount,0) ) over (partition by left(yyyy_mm,4) order by yyyy_mm ) as 当年累计销售额,
ifnull(sale_amount,0)/sum(ifnull(sale_amount,0) ) over(partition by left(yyyy_mm,4))*100  as '当年每月占比',
sum(ifnull(sale_amount,0) ) over (partition by left(yyyy_mm,4) order by yyyy_mm )/
sum(ifnull(sale_amount,0) ) over(partition by left(yyyy_mm,4))*100 as '当年每月累计占比'
from (
select DATE_FORMAT(orderdate,'%Y-%m')  as 'yyyy_mm',
sum(b.priceEach*b.quantityOrdered ) as 'sale_amount' 
from  classicmodels.orders a left join 
classicmodels.orderdetails b on a.orderNumber =b.orderNumber 
group by DATE_FORMAT(orderdate,'%Y-%m')) a

如图

4.lag 函数重要操作要点

1.lag(sale_amount,12) 意思就是 表示取前12行的数据, 2.这个方法必须建立在1年12月没缺失的基础上的,所以建议 日期用 日期维表处理。来保证1年12个月没有缺失 具体可以看下mysql 官方的帮助 dev.mysql.com/doc/refman/... This LAG() function

总结

以上是 计算 环比、环比增长率、同比、同比增长率 ,占比,Mysql 8.0 实例(最简单的方法之一) 此案例 MySQL 8.0,主要通过 窗口函数完成,做数分和数据开发的同学可以看下 ,希望有对你们有一些指导意义

相关推荐
坚定信念,勇往无前29 分钟前
electron-vite 安装better-sqlite3
javascript·数据库·electron
大明者省33 分钟前
Ubuntu22.04 宝塔面板与 XFCE 远程桌面端口兼容性分析
运维·服务器·数据库·笔记
liudanzhengxi1 小时前
巧用ULN2003A轻松扩展单片机IO口
数据库·mongodb
Teable任意门互动1 小时前
深度解析:AI 赋能开源多维表格,实现企业全场景数据整合与高效应用
数据库·人工智能·低代码·信息可视化·开源·数据库开发
还是鼠鼠2 小时前
AI掘金头条新闻系统 (Toutiao News)-相关推荐
后端·python·mysql·fastapi·web
DevOpenClub2 小时前
职教高考及高职分类招生控制线 API 接口
java·数据库·高考
funnycoffee1232 小时前
华为S5736交换机3层ECMP负载方式
linux·服务器·数据库
添砖java‘’2 小时前
MySQL复合查询
数据库·mysql
星川水月2 小时前
Access数据库快速入门——外部数据导入和SQL简单查询
数据库·sql·access