SQL计算月环比、月同比

您所在的位置:网站首页 每月环比增长率怎么算 SQL计算月环比、月同比

SQL计算月环比、月同比

#SQL计算月环比、月同比| 来源: 网络整理| 查看: 265

在工作的过程中,经常会使用到环比、同比,那关于如何用SQL去写环比和同比呢?非常简单,表自联以及interval函数,轻松实现。 interval 1 month,环比 interval 1 year ,同比

一、准备数据

为了快速理解,我建了一个表,关于订单金额的(数据是随机数,非真实数据) 数据格式如下: 数据尽量极简,所以就只有日期和订单金额。 (格式是之前一个面试官给我举的例子)

二、计算

1、月环比 代码:

##月环比 select substr(a.d,1,7) as month ,a.d,a.orderpay,b.dd,b.originalday,b.orderpay, (a.orderpay-b.orderpay)/b.orderpay as month_rate from (select DATE_FORMAT(CONCAT(datetime,'-01'),'%Y-%m-%d') as d ,orderpay from ordertable) a left join (select DATE_ADD(DATE_FORMAT(CONCAT(datetime,'-01'),'%Y-%m-%d'),INTERVAL 1 month )as dd ,DATE_FORMAT(CONCAT(datetime,'-01'),'%Y-%m-%d')as originalday,orderpay from ordertable) b on a.d=b.dd

结果: 从结果可以看到,月环比的计算逻辑:在原有的时间加上一个月与原表连接即可得到本月与上个月的信息。结果有几个月份是null,原因是我造的数据没有11月份的,所以才没有计算,这个可忽略。 在这里插入图片描述 2、月同比 同比计算也很简单。同比这里是今年的N月,与去年的N月的比较。 代码: 逻辑没变,就是将月换成年即可。

##月同比 select substr(a.d,1,7) as month ,a.d,a.orderpay,b.dd,b.originalday,b.orderpay, (a.orderpay-b.orderpay)/b.orderpay as month_rate from (select DATE_FORMAT(CONCAT(datetime,'-01'),'%Y-%m-%d') as d ,orderpay from ordertable) a left join (select DATE_ADD(DATE_FORMAT(CONCAT(datetime,'-01'),'%Y-%m-%d'),INTERVAL 1 year )as dd ,DATE_FORMAT(CONCAT(datetime,'-01'),'%Y-%m-%d')as originalday,orderpay from ordertable) b on a.d=b.dd

结果: 在这里插入图片描述



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3