今天继续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
到此,我们几种对比的方式已经都实现了,都是使用月的维度进行演示的,使用日、周、年维度都是相同的思路,只要把顺序排列好就行了。
阵法是玩家和伙伴一起配合不同的站位来对抗各种怪物团的系统,是大话神仙的战斗乐趣之一,10种不同的阵法随着玩家主角的等级提升而逐步开放,阵法在提供不同站位的同时还可以给玩家提供相应阵法带来的额外属性加成效果和队伍先攻值。玩家可以在游戏中获得阅历奖励,并提升阵法奇术 1 天阵 是最早开放的阵法,提升天...
1 问 如果是人工繁殖的蟹苗,应询问蟹苗的日龄、饵料投喂情况、淡化处理过程以及池内蟹苗的密度。饲养管理较好的蟹苗,日龄一般在4~5天,经过4~5天的淡化处理后,池内蟹苗的密度较大,且比较活跃。如果购买的是天然蟹苗,则要了解蟹苗捕捞的天数及淡化处理情况;如未经淡化处理千万不要购买。 2 称 将准备出...
常言道,九死一生。创业是一项高风险不确定的事情,需要特别谨慎才行。虽然创业成功,会带来巨大的回报,但是我们也千万不能忽视创业的巨大风险,尤其对于普通人来说更是如此。因为普通人试错成本太高了,败则死无葬身之地,这可不是吓唬在看的诸位。 大家或许看过这种新闻报道,某某某看中一个项目,觉得能赚大钱,...
随着直播热度不断增加,越来越多的人要想申请加入淘宝直播,很多人都很关心怎样才能加入淘宝直播,下面就给大家讲下成为淘宝直播的要求吧。 第一,必须要有一个绑定了实名认证的淘宝账号 第二,根据账号属性的不同,具体的要求也不同,具体如下: 非商家且是个人主播,基本门槛满足一下两个条件即可: 条...
企业网站不仅需要SEO或竞价,当然全网推广方法也需要。一.企业官方自媒体微博/博客通过博客或微博直接引入,可以直接带来潜在的客户,省去了用户搜索查找的麻烦,可以方便的增加对应的网站 企业网站不仅需要SEO或竞价,当然全网推广方法也需要。 一.企业官方自媒体微博/博客 通过博客或微博直接引入,可...
产品的更新和投入是保持企业活力和提高市场占有率竞争力的重要措施,如何有效的通过新品的市场投入和有效运作,更好的带动企业效益和利润的增加,是保证企业可持续发展的重要组成部分一、新品的 产品的更新和投入是保持企业活力和提高市场占有率竞争力的重要措施,如何有效的通过新品的市场投入和有效运作,更好的带动企...
做自媒体一天收入相当于我一年工资了,走,做自媒体去。也是从这两次事件开始,自媒体火了。可是,两年过去了,99%的自媒体人还在苦苦探索盈利模式。做自媒体,收这样高级别的广告费,除了文 做自媒体一天收入相当于我一年工资了,走,做自媒体去。也是从这两次事件开始,自媒体火了。可是,两年过去了,99%的自媒...
经常有人问:做公众号能不能转载其他号的文章?会不会不好?首先抛出我的观点:能,肯定的。容我简单说一下:1转载不是什么丢人的事,恰恰相反,只要随便看一些大号就会发现,他们每天都需要转 经常有人问: 做公众号能不能转载其他号的文章?会不会不好? 首先抛出我的观点: 能,肯定的。 容我简单说一下...
《诗经》是中国文学的宝典,其含有古典先贤的思想精髓,藏有上古时期的浪漫情愫,每一句诗文都含有诗情画意,藏有“脉脉不得语“的婉约灵动之感,情谊绵绵也。因此通过诗经给女孩起名字,会有一 《诗经》是中国文学的宝典,其含有古典先贤的思想精髓,藏有上古时期的浪漫情愫,每一句诗文都含有诗情画意,藏有“脉脉不得...
有人说扬州属于经济强的苏南,更多人说属于经济弱的苏北。如果以长江而论,当然属于苏北。但争来争去终于给扬州,甚至泰州、南通等地。找到一个当地人感觉有面子而苏北苏南地域人们又都认可的说 有人说扬州属于经济强的苏南,更多人说属于经济弱的苏北。如果以长江而论,当然属于苏北。但争来争去终于给扬州,甚至泰州、...
如果有人告诉你他要送辆车给你,中置引擎后轮驱动,360度全景大天窗……妹子你可千万别天真的以为是这样的车:因为它也有可能是以下这几款:这几日的长沙城风和日丽,一些耐不住好天气的妹子和初春的梧桐树新芽一样蠢蠢欲动。正可谓— 如果有人告诉你他要送辆车给你,中置引擎后轮驱动,360度全景大天窗……妹子你...
2022年七月,八月,天气炎热,几乎每日都要开启“昼蒸夜煮”的模式,都躲在家里,吹着空调,看着电视,吃着西瓜,似乎成为了大多数人的宅家三部曲。转眼间,到了九月,气温下降了不少,但是当很多朋友收到七八月份电费账单的时候,心 2022年七月,八月,天气炎热,几乎每日都要开启“昼蒸夜煮”的模式,都躲在家...
扫墓立碑是作为小辈必做的事情之一,这不眼见着就要寒衣节了了,由于很多地方都有立碑这一说到,所以关于立碑墓碑上刻什么图案好一直是大家讨论的焦点,下面小编就和大家一起看看。墓碑上刻什么图案好这要看地方的讲究。墓地是相当有气运 扫墓立碑是作为小辈必做的事情之一,这不眼见着就要寒衣节了了,由于很多地方都有...
iPhone14promax在官方直营店依旧没现货,包括京东或者天猫旗舰店,想买现货的朋友们在官网蹲到了吗?目前,iPhone14promax黄牛加价1200,可以自己卖赚点钱,如果自己加钱买的话就没必要了。iPhone iPhone14promax在官方直营店依旧没现货,包括京东或者天猫旗舰店,...
冬至烧纸钱是很多地区都有的习俗之一,但由于这是祭祀祖先,所以烧纸的时辰也成了大家茶余饭后讨论的焦点,下面小编就和大家一起看看2022冬至烧纸钱可以提前烧吗宜什么时间点烧。2022冬至烧纸钱可以提前烧吗看地方的讲究,毕竟十 冬至烧纸钱是很多地区都有的习俗之一,但由于这是祭祀祖先,所以烧纸的时辰也成了...