环比、环比增长率、同比、同比增长率 ,占比,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,主要通过 窗口函数完成,做数分和数据开发的同学可以看下 ,希望有对你们有一些指导意义

相关推荐
小陈工1 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
0xDevNull5 小时前
MySQL数据冷热分离详解
后端·mysql
科技小花5 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸5 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain5 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希6 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神6 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员6 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java6 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿7 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb