今天继续MySQL的问题,也是一个常见的问题,就是计算同比和环比问题,然后在此思路的基础上做一个复合增长率的计算。在MySQL8.0之前,同比环比的思路是通过LEFT JOIN去把上一期的数据求出来,然后再进行计算。再MySQL8.0之后,计算方式就很简单了,通过窗口函数可以很简单的解决,所以今天介绍的是窗口函数的解决方案。
首先是数据的准备,数据如下,我们准备了从2020-2022三年每天三个产品的交易数据,这里就只把最关键的几个字段给留出来了↓
环比、同比一般是计算月度的,所以我们第一步需要先把数据转换成月维度的数据,这里只需要用到最基础的SQL操作,GROUP BY一下就行了,SQL语句和结果如下↓
SELECT
product,
DATE_FORMAT( s_date, "%Y-%m" ) AS ym,
SUM( amount ) AS amount,
SUM( gmv ) AS gmv
FROM
orders
GROUP BY
product,ym
这样我们就得到了每个产品每个月的金额和数量了,而且我们这里是按照产品、月份排序的。然后先计算环比,我们就用数量进行举例了,金额是一个道理。思路是我们需要找到当前月份上一个月的销售数量,使用窗口函数的LAG函数,进行一次偏移就行了。就可以得到上月的金额,然后还需要按产品进行分组,也就是OVER里面的PARTION BY 产品,然后通过环比的公式计算一下就行了,SQL语句个结果如下↓
WITH cte AS(
SELECT
product,
DATE_FORMAT( s_date, "%Y-%m" ) AS ym,
SUM( amount ) AS amount,
SUM( gmv ) AS gmv
FROM
orders
GROUP BY
product,ym
ORDER BY
product,ym)
SELECT
product,ym,amount,
LAG(amount,1) OVER(PARTITION BY product ORDER BY ym) AS lm_amount,
CONCAT(ROUND((amount - LAG(amount,1) OVER(PARTITION BY product ORDER BY ym))/
LAG(amount,1) OVER(PARTITION BY product ORDER BY ym),2),"%") AS MoM_amount
FROM
cte
这里简单介绍一下,同比和环比的公式↓
环比 = (本月值 – 上月值)/上月值,或者 本月值/上月值-1
同比 = (本月值 – 上年同期值)/上年同期值,或者 本月值/上年同期值-1
然后就是同比,思路和环比一样的,只是偏移的月份从1变成了12,SQL语句和结果如下↓
WITH cte AS(
SELECT
product,
DATE_FORMAT( s_date, "%Y-%m" ) AS ym,
SUM( amount ) AS amount,
SUM( gmv ) AS gmv
FROM
orders
GROUP BY
product,ym
ORDER BY
product,ym)
SELECT
product,ym,amount,
LAG(amount,12) OVER(PARTITION BY product ORDER BY ym) AS ly_amount,
CONCAT(ROUND((amount - LAG(amount,12) OVER(PARTITION BY product ORDER BY ym))/
LAG(amount,12) OVER(PARTITION BY product ORDER BY ym),2),"%") AS YoY_amount
FROM
cte
最后是一个巩固练习,使用窗口函数计算复合增长率。先介绍一下复合增长率的公式,就是使用本期的数据除以第一期的数据,然后根据间隔开方,再减一,公式如下↓
CAGR = (Ending Value/Beginning Value)^(1/N)-1
所以我们需要计算两个值,第一个是首期的值,第二个是间隔的期数。两个值都是用窗口函数来计算的,首期使用FIRST_VALUE计算,间隔就用ROW_NUMBER。最后使用我们上面的公司就能计算出复合增长率了,SQL语句和结果如下↓
WITH cte2 AS(
WITH cte AS(
SELECT
product,
DATE_FORMAT( s_date, "%Y-%m" ) AS ym,
SUM( amount ) AS amount,
SUM( gmv ) AS gmv
FROM
orders
GROUP BY
product,ym
ORDER BY
product,ym)
SELECT
product,ym,amount,gmv,
FIRST_VALUE(amount) OVER(PARTITION BY product ORDER BY ym) AS first_amount,
ROW_NUMBER() OVER(PARTITION BY product ORDER BY ym) as rn
FROM
cte)
SELECT
product,ym,amount,first_amount,rn,
CONCAT(ROUND((POWER(1.0*amount/first_amount, 1.0/NULLIF(rn-1,0))-1) * 100,2),"%") AS "月均复合增长率"
FROM
cte2
到此,我们几种对比的方式已经都实现了,都是使用月的维度进行演示的,使用日、周、年维度都是相同的思路,只要把顺序排列好就行了。
1 问 如果是人工繁殖的蟹苗,应询问蟹苗的日龄、饵料投喂情况、淡化处理过程以及池内蟹苗的密度。饲养管理较好的蟹苗,日龄一般在4~5天,经过4~5天的淡化处理后,池内蟹苗的密度较大,且比较活跃。如果购买的是天然蟹苗,则要了解蟹苗捕捞的天数及淡化处理情况;如未经淡化处理千万不要购买。 2 称 将准备出...
很多朋友都在上找项目,有的朋友也被割过韭菜,因为做互联网的人没有谁是没被割过韭菜的,有的韭菜终有一天会茁壮成长,有的韭菜肯定会被无情的镰刀割到你怀疑人生。 韭菜就是被割的,你不割它会烂在地里。韭菜内心愤愤不平,继续辗转到下一块地再次茁壮生长,殊不知,山顶、山腰、山谷都可以割,而且镰刀更加锋利。...
导语:6款百元左右,适合自饮的纯粮白酒,公认好喝,有您喝过的吗? 大家都知道,白酒就算是再便宜,喝的时候最好选择纯粮食酒,劣质的勾兑酒不仅喝的时候口感比较差,而且还很容易上头伤身体,而真正的纯粮好酒,喝完不仅不容易上头,对身体的伤害比较低,适量饮酒对身体也有一些好处。 平时生活...
笔记本电脑,什么样的配置,够大学生用四年?其实只要够穷,什么电脑都能用四年。所以今天,Yo哥就分类探讨笔电选购的五种情况!什么样的配置,用得最久。准备把电脑用足四年的小伙伴,可以点 笔记本电脑,什么样的配置,够大学生用四年?其实只要够穷,什么电脑都能用四年。所以今天,Yo哥就分类探讨笔电选购的五种...
百度到目前为止拥有超过8亿万用户,是巨大的流量池,利用好它可以帮助广告主实现产品的变现和产品的转化。所以,我们一起来看下关于百度产品推广效果这方面的知识点吧。一、百度产品推 百度到目前为止拥有超过8亿万用户,是巨大的流量池,利用好它可以帮助广告主实现产品的变现和产品的转化。所以,我们一起来看下...
很多人由于工作生活等原因,一个微信号远远不能满足我们日常使用,很多人都是生活一个号,工作一个号。虽然我们需要两个微信来用,但是还不想要办理多余的手机卡。这样我们原来是不是你都以为只 很多人由于工作生活等原因,一个微信号远远不能满足我们日常使用,很多人都是生活一个号,工作一个号。虽然我们需要两个微信...
经常有人问:做公众号能不能转载其他号的文章?会不会不好?首先抛出我的观点:能,肯定的。容我简单说一下:1转载不是什么丢人的事,恰恰相反,只要随便看一些大号就会发现,他们每天都需要转 经常有人问: 做公众号能不能转载其他号的文章?会不会不好? 首先抛出我的观点: 能,肯定的。 容我简单说一下...
羊了个羊游戏的玩法规则是什么?玩家在玩这款游戏的时候,刚开始很多人都不知道这款游戏怎么玩,由于不清楚游戏的规则,所以很多玩家在初期都会走很多弯路,今天游戏鸟小编给大家带来游戏的规则 羊了个羊游戏的玩法规则是什么?玩家在玩这款游戏的时候,刚开始很多人都不知道这款游戏怎么玩,由于不清楚游戏的规则,所以...
哈喽,各位小伙伴,今天给大家分享下手机的字体在哪里设置,这里边的字体一般包括苹果系统字体和安卓系统的字体设置。苹果系统字体大小设置一般来说系统字体大小设置的步骤都差不多,在这里我带 哈喽,各位小伙伴,今天给大家分享下手机的字体在哪里设置,这里边的字体一般包括苹果系统字体和安卓系统的字体设置。 苹...
泡温泉是冬季比较常见的一种休闲放松方式,很多人都会去泡温泉,尤其是年轻人。泡温泉也会有一定的讲究,尤其是穿着,最好穿防水的内裤,这样可以防止感染妇科疾病,降低感染风险。泡温泉穿什么内裤防止感染防水的内裤。泡温泉时穿防水内 泡温泉是冬季比较常见的一种休闲放松方式,很多人都会去泡温泉,尤其是年轻人。泡...
“您好,这里是白银市公安局反诈骗中心,请问您最近有没有接到过诈骗电话或信息,让您告知手机验证码、点击陌生链接、扫陌生二维码,或者以各种理由要求您转账汇款的……”近日,记者来到白银市打击治理电信网络新型犯罪违法犯罪中心,看 “您好,这里是白银市公安局反诈骗中心,请问您最近有没有接到过诈骗电话或信息,...
要说近期的天气真的像小孩子的脸说变就变,前一秒还热得不行,后一秒就极速下降了20多度,也正是因为这样大家纷纷期待能升温,下面小编就以武汉为例,一起看看武汉10月下旬还会升温吗。武汉10月下旬还会升温吗最新就目前来看武汉1 要说近期的天气真的像小孩子的脸说变就变,前一秒还热得不行,后一秒就极速下降了...
对于分手后还想复合的心理是完全可以理解的,无非两种原因,一是依旧喜欢,二是找不到比前任更好的对象。当你分手后想复合首先考虑下你们是因为什么分的手,你是分手方还是被分手方,这个区别还是很大的。分手后想复合要不要联系如果你真 对于分手后还想复合的心理是完全可以理解的,无非两种原因,一是依旧喜欢,二是找...
木瓜番木瓜怎么辨认 一、木瓜是什么样的果树 1、番木瓜的特征集 木瓜是一个正式的中名。这个名字来自台湾植物名录。因为它原产于热带美国,所以在中国被引进和种植。为了区别于我国制造的玫瑰科木瓜,它被称为木瓜;学名是Carica papaya Linn.,正式命名发表于1753年;别名包括木瓜...
深圳南山好玩的地方 1 欢乐海岸 景区简介: 快乐海岸总面积约125万平方米,其中水域面积近一半。总的来说,快乐海岸最大的特点就是以水为魂。 深圳市十大著名旅游景点? 景区亮点: 快乐海岸汇聚全球大师智慧,以海洋文化为主题,以生态环境保护为理念,以创新商业为主体,以创造城市滨海健...