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

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

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

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

分享给朋友:

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

大话西游阵法,仙族八卦阵法大话

大话西游阵法,仙族八卦阵法大话

阵法是玩家和伙伴一起配合不同的站位来对抗各种怪物团的系统,是大话神仙的战斗乐趣之一,10种不同的阵法随着玩家主角的等级提升而逐步开放,阵法在提供不同站位的同时还可以给玩家提供相应阵法带来的额外属性加成效果和队伍先攻值。玩家可以在游戏中获得阅历奖励,并提升阵法奇术 1 天阵 是最早开放的阵法,提升天...

红烧五花肉的做法,五花肉做法 红烧

红烧五花肉的做法,五花肉做法 红烧

1 红烧肉,最解馋的一道菜。制作方法不复杂,其制作的关键点是烧炖的时间。没有一个多小时的烧炖,就烧不出软糯的口感。现在正是桂花盛开的时候,摘一把桂花放入肉中烧炖,别有一番滋味。 原料:五花肉750克,广东菜心200克,桂花适量,冰糖40克,草菇老抽1勺,蒸鱼豉油1勺,蚝油适量,香叶2片,桂皮1块,...

三国塔防蜀传第15关攻略攻略,三国塔防蜀传单挑条件

三国塔防蜀传第15关攻略攻略,三国塔防蜀传单挑条件

又跟大家见面了,今天小编就来给大家送上三国塔防蜀传攻略之第十五关图文攻略,今天爆发啦,请大家继续关注! 1 今天第十五关就是收服马超法正啦,张鲁没想到派出马超是肉包子打狗有去无回呀。 2 这一关出场钱数比较多,我们先把张飞放到中间路线上,在上面进攻路线放置一个3级枪兵,一个3级弓兵,一个3级术士。...

数据造假黑产技术帖:如何给微信公众号、微博大V、直播网红刷量

数据造假黑产技术帖:如何给微信公众号、微博大V、直播网红刷量

如果只看、大V、直播红人的造假行为,只能看到简单的操作,比如刷阅读量,刷点赞,直播通过机器或者水军制造假观众。深层次上,我们需要从数据造假黑产业的技术内核出发,回溯产业链的各个环节,才能透过表面看到数据造假给行业带来多大的影响和破坏力。 数据造假不仅发生在网红经济,也肆虐于游戏、、互联网金融等...

鹅厂真是把校招玩明白了

鹅厂真是把校招玩明白了

拆分了一下鹅厂工资构成,根据岗位和水平,基本工资再19k-22k,18薪,每个月房补4k,股票也是分等级6-22万,分两年发,签字费3w。这样算下来,低的有40万,高的有60万。上管拿40万的这种叫白菜价; 有以下几方面的原因: 1、最需要的不是经验,而是创新。 比如金融、地产行...

钻石夺宝201必中水晶吗(荣耀水晶抽361次多少钱)

钻石夺宝201必中水晶吗(荣耀水晶抽361次多少钱)

前言: 各位小伙伴大家好,这里是不仅游戏打得6,长得还很帅的熊猫哥哥~ 王者荣耀中最有价值的游戏道具之一就是荣耀水晶,玩家们可以使用荣耀水晶来兑换特定商店中的皮肤和英雄,例如武则天、小乔-天鹅之梦等等,有很多高人气皮肤。 荣耀水晶需要通过积分夺宝来获取,非常看运气,很多手气...

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

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

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

网络营销策略有哪些(推荐网络营销的5种策略)

网络营销策略有哪些(推荐网络营销的5种策略)

企业常用的网络营销策略有:充分利用百度平台,加强推广与网站运营的结合,配置合适的网络营销团队。网络营销一直在变化,网络营销策略也应与时俱进。继续保持有效策略,调整或放弃无效策略。那 企业常用的网络营销策略有:充分利用百度平台,加强推广与网站运营的结合,配置合适的网络营销团队。 网络营销一直在变化...

抖音封面怎么设置(抖音怎么单独添加封面)

抖音封面怎么设置(抖音怎么单独添加封面)

三联屏封面的设置首先,保存一张三联屏封面的底图下载一个叫美图秀秀的软件,点开美图秀秀,在首页点击图片美化然后选择我们刚刚保存好的底图,点击进去,然后选择底下工具栏里的编辑功能进入之 三联屏封面的设置 首先,保存一张三联屏封面的底图 下载一个叫美图秀秀的软件,点开美图秀秀,在首页点击图片美化...

百度该如何做推广(百度做推广从以下两个方面入手)

百度该如何做推广(百度做推广从以下两个方面入手)

百度到目前为止拥有超过8亿万用户,是巨大的流量池,利用好它可以帮助广告主实现产品的变现和产品的转化。所以,我们一起来看下关于百度产品推广效果这方面的知识点吧。一、百度产品推   百度到目前为止拥有超过8亿万用户,是巨大的流量池,利用好它可以帮助广告主实现产品的变现和产品的转化。所以,我们一起来看下...

如何做好网络推广(分享做网络推广的3种方式)

如何做好网络推广(分享做网络推广的3种方式)

有关企业为何要做网络推广,对企业有什么作用益处,这针对很多企业很有可能都还没真实了解企业为何要做网络推广,互联网推广对企业有哪些实际益处,下边,知名品牌益众帮,就以互联网营销这一话 有关企业为何要做网络推广,对企业有什么作用益处,这针对很多企业很有可能都还没真实了解企业为何要做网络推广,互联网推广...

一个营业执照可以开几个店铺(一个营业执照两个店面可以吗)

一个营业执照可以开几个店铺(一个营业执照两个店面可以吗)

一个公司能申请几个天猫旗舰店?虽然距离618还有一个多月,但是很多商家都已经在摩拳擦掌的准备了,还有很多已经有了天猫店并发展的不错,想要开设第二家或第三家店铺的商家,但是开设多家天 一个公司能申请几个天猫旗舰店?虽然距离618还有一个多月,但是很多商家都已经在摩拳擦掌的准备了,还有很多已经有了天猫...

手机照片怎么添加文字(手机怎样在图片上编辑文字)

手机照片怎么添加文字(手机怎样在图片上编辑文字)

如何给你的照片添加喜欢的文字,让照片变得更好看?赶快看过来,你可能会说用微信就可以,下面给你分享一种方法,效果会更好,操作还简单,更好的是还可以拼长图,赶快点赞关注收藏转发一下,和 如何给你的照片添加喜欢的文字,让照片变得更好看?赶快看过来,你可能会说用微信就可以,下面给你分享一种方法,效果会更好...

怎么做广告策划(宣传策划方案怎么做)

怎么做广告策划(宣传策划方案怎么做)

广告主收到的广告策划信息材料多种多样,内容十分丰富,因此广告主收到的信息量相当大而复杂。广告策划案的一些写作技巧也涉及到如何以一种易于理解的方式表达这些信息,并使其在内容和形式上更 广告主收到的广告策划信息材料多种多样,内容十分丰富,因此广告主收到的信息量相当大而复杂。广告策划案的一些写作技巧也涉...

农历十月初一是阳历的哪一天(十月初一节日什么意义)

农历十月初一是阳历的哪一天(十月初一节日什么意义)

寒衣节是很多北方地区都有的风俗习惯,但由于该节日并不是按照阳历来讲的而是按照阴历,所以农历十月初一是阳历的哪一天成了很多人都好奇的,下面小编就和大家一起看看十月初一节日什么意义。农历十月初一是阳历的哪一天农历十月初一是1 寒衣节是很多北方地区都有的风俗习惯,但由于该节日并不是按照阳历来讲的而是按照...