当前位置:首页 > 知识分享 > 正文内容

今日知识分享年均增速怎么计算

3年前 (2023-05-09)知识分享133

今天继续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

到此,我们几种对比的方式已经都实现了,都是使用月的维度进行演示的,使用日、周、年维度都是相同的思路,只要把顺序排列好就行了。

扫描二维码推送至手机访问。

版权声明:本文由阿龙玩站网发布,如需转载请注明出处。

本文链接:https://www.longge2021.cn/zhideyikan/25063.html

分享给朋友:

“今日知识分享年均增速怎么计算” 的相关文章

千里之外随时远程实时监控(无线小型摄像头能用多久)

千里之外随时远程实时监控(无线小型摄像头能用多久)

讲真,如果说你安装监控的地方没有WiFi,没有无线网络,有想要远程查看实时视频,这种情况下有没有符合条件的摄像头呢?不要怀疑,这种还真的有。毕竟在科技高度发展的今天,上太空的飞船都造出来,还造不出这种物联网技术运用的无线传输设备吗?所以,今天速名网要说到的话题就是在没有网络的情况下,我们可以...

电动车选哪个品牌比较好(十大电动车品牌排行榜)

电动车选哪个品牌比较好(十大电动车品牌排行榜)

您在阅读前请点击上面的“关注”二字,后续会为您提供更多有价值的相关内容,感谢您的支持。 电动车虽然总的来说是经济实惠,但从大的市场来看,电动车现在已经形成了“万亿消费大市场”,拥有很高的消费能力,而电动车品牌也非常多,从低端到高端,应有尽有,品牌和产品越丰富,对于车主而言,选择性更多了,...

如何建立淘宝网店(如何开网店淘宝步骤)

如何建立淘宝网店(如何开网店淘宝步骤)

想要成为淘宝店铺的商家,首先要做的就是拥有自己的淘宝店铺,这就需要进行店铺的注册,下面学得起课堂就详细的为大家介绍淘宝如何注册网店,淘宝注册网店的详细流程。1、淘宝账号申请还没有申 想要成为淘宝店铺的商家,首先要做的就是拥有自己的淘宝店铺,这就需要进行店铺的注册,下面学得起课堂就详细的为大家介绍淘...

seo优化网站排名该怎么做(分享做seo优化网站排名的4种方法)

seo优化网站排名该怎么做(分享做seo优化网站排名的4种方法)

随着搜索引擎系统的不断优化和完善,在当前互联网用户数量和使用频率不断增加的情况下,站点也越来越多的情况下,seo优化如何做好网站排名,让用户更能注意到我们呢?接下来小编就跟大家分 随着搜索引擎系统的不断优化和完善,在当前互联网用户数量和使用频率不断增加的情况下,站点也越来越多的情况下,seo优化...

阶梯电费收费标准2022天津(家庭用电阶梯价格表)

阶梯电费收费标准2022天津(家庭用电阶梯价格表)

2022年七月,八月,天气炎热,几乎每日都要开启“昼蒸夜煮”的模式,都躲在家里,吹着空调,看着电视,吃着西瓜,似乎成为了大多数人的宅家三部曲。转眼间,到了九月,气温下降了不少,但是当很多朋友收到七八月份电费账单的时候,心 2022年七月,八月,天气炎热,几乎每日都要开启“昼蒸夜煮”的模式,都躲在家...

农历十月初一为什么要早回家(农历十月初一是鬼节吗)

农历十月初一为什么要早回家(农历十月初一是鬼节吗)

十月初一送寒衣是很多北方地区都有的习俗,但由于该节日作为四大鬼节之一,所以很多讲究都会出现在我们生活中,因此农历十月初一为什么要早回家成了大家都在问的,下面小编就和大家一起看看农历十月初一是鬼节吗。农历十月初一为什么要早 十月初一送寒衣是很多北方地区都有的习俗,但由于该节日作为四大鬼节之一,所以很...

羊血的功效与作用及营养价值(吃羊血有什么好处和坏处)

羊血的功效与作用及营养价值(吃羊血有什么好处和坏处)

羊血是比较少见的一种动物血液,它里面也含有丰富的营养成分,可以起到很不错的功效与作用,适量食用可以补血止血、祛瘀解毒等,补充人体所需的营养,但是服用不当,也可能会增加肠胃负担,引起消化不良以及肠胃不适。羊血的功效与作用及 羊血是比较少见的一种动物血液,它里面也含有丰富的营养成分,可以起到很不错的功...

奥粒绒和摇粒绒一样吗(奥粒绒保暖效果怎么样)

奥粒绒和摇粒绒一样吗(奥粒绒保暖效果怎么样)

随着天气的变冷,很多友友都开始为自己置办加绒的衣服,而近期一种名为奥粒绒的面料便成了各大直播间的主推,不过由于该面料和之前的摇粒绒外观有一点点的相似,下面小编就和大家一起看看奥粒绒保暖效果怎么样。奥粒绒和摇粒绒一样吗奥粒 随着天气的变冷,很多友友都开始为自己置办加绒的衣服,而近期一种名为奥粒绒的面...

2022冬至之后是不是一天比一天长(冬至之后是不是昼长夜短)

2022冬至之后是不是一天比一天长(冬至之后是不是昼长夜短)

冬至是二十四节气中的第22个节气,个节气,但由于每每冬至后后昼夜长短都会出现变化,所以每当冬至来临之际,大家常常好奇春2022冬至之后是不是一天比一天长,下面就和大家一起看看冬至之后是不是昼长夜短。2022冬至之后是不是 冬至是二十四节气中的第22个节气,个节气,但由于每每冬至后后昼夜长短都会出现...

压岁钱是2023年除夕给还是大年初一给(除夕夜几点发压岁钱)

压岁钱是2023年除夕给还是大年初一给(除夕夜几点发压岁钱)

压岁钱是2023年除夕给还是大年初一给是大家常聊的,对于小孩子来讲一年中最为喜爱的节日除了寒暑假就是春节了,毕竟过年长辈给的压岁钱可以说是一笔不小的收入了,下面小编就和大家一同看看什么是压岁钱。压岁钱是2023年除夕给还 压岁钱是2023年除夕给还是大年初一给是大家常聊的,对于小孩子来讲一年中最为...

iPhone14双十一官网会降价吗(苹果14双11大概会是多少钱)

iPhone14双十一官网会降价吗(苹果14双11大概会是多少钱)

iPhone14双十一官网一般是没有优惠的,但其他电商平台是会有折扣的,每年都是如此,更何况今年的iPhone14销量并不是很好,所以想入手新机的朋友们可以期待双十一的折扣哦!iPhone14双十一官网会降价吗不会,官网 iPhone14双十一官网一般是没有优惠的,但其他电商平台是会有折扣的,每年...

微单相机销量排行?(2019微单相机排行)

微单相机销量排行?(2019微单相机排行)

2019微单相机排行 微单相机销量排行? 微单作为目前相机市场最热门的机型,受到了消费者们的普遍关注。虽然手机拍摄性能越来越强,但是选购微单的也大有人在。今天我们就给大家带来了,京东商城微单销量排行榜TOP5。要知道在竞争激烈的微单市场要成为销量前五名的产品可不是容易事,必须具备很...

电解质水是不是智商税?(电解质水可以长期喝吗)

电解质水是不是智商税?(电解质水可以长期喝吗)

电解质水可以长期喝吗 电解质水是不是智商税? 各大电商平台爆发式销售,一瓶健身教练,社交平台策略笔记铺天盖地..电解质这一概念,早已风靡全网,相关产品的销量也随之上升。 根据2022年电解质饮料趋势报告,电解质饮料已成为饮用水轨道的新出风口,销量同比增长225%,超过能量饮料...

南通市海门市十大著名旅游景点?(海门旅游景点大全)

南通市海门市十大著名旅游景点?(海门旅游景点大全)

海门旅游景点大全 近年来,朝阳区积极引导沿海休闲度假旅游、农业生态旅游、名胜古迹文化旅游等特色旅游项目的发展,不断完善景区设施,特别是以国家特色城镇海门镇为核心,以莲花峰景区建设为重点,继续挖掘和整合旅游资源,打造朝阳旅游品牌,进一步加强宣传推广,提高朝阳旅游的知名度和影响力。 南...

2023兔年搬新家怎么选吉日(2023年最好最吉利的入宅吉日有哪些天)

2023兔年搬新家怎么选吉日(2023年最好最吉利的入宅吉日有哪些天)

2023兔年搬新家怎么选吉日是大家经常讨论的,毕竟在我国只要一遇到大事,算日子指定是必不可少的一步,搬家就是这样,虽说搬新家和结婚相比甚是渺小,但是呢为了讨个吉利大家每每搬家的时候都会有各种的讲究。2023兔年搬新家怎么 2023兔年搬新家怎么选吉日是大家经常讨论的,毕竟在我国只要一遇到大事,算日...