SQL面试真题解答 数据统计分析,求“同比、环比”等(SQL窗口函数使用)

SQL面试真题解答 数据统计分析,求"同比、环比"等(SQL窗口函数使用)

环比、环比增长率、同比、同比增长率,根据百度百科上的 说明:

环比增长率 环比增长率,一般是指和上期相比较的增长率。 环比增长率=(本期的某个指标的值-上一期这个指标的值)/上一期这个指标的值*100%。 例如,今年5月与今年4月比较。环比更侧重于体现数的短期变化,能够反映出最新趋势和动态。

同比增长率 某个指标的同期比=(当年的某个指标的值-上年同期这个指标的值)/上年同期这个指标的值 即:同比增长率=(当年的指标值-上年同期的值)÷上年同期的值*100%。例如,今年5月与去年5月相比较。同比能够反映出长期的趋势和周期性变化。

解题思路:

保证数据完整,每年每月数据不缺失。

01.将数据抽取年份,月份字段,按照年月聚合求总数。

02.利用SQl窗口函数 LAG() 或者 LEAD() 获取前后数据。

03.与昨日比较:按照"日期"排序,取昨日数据。

04.环比:本月与上月比较,按照"月份"排序,取上一个月份数据。

05.同比:今年本月与去年本月比较,将数据按照"月份"分组,按照"年份"排序,取上一个年份数据。

本SQL示例:

未按照月份聚合求和,仍是按照每天查询。 对比昨天,对比上月同一天,对比上年同一天。

考题扩展延伸:

与十天前对比,与三个月前对比,与六个月前对比,与九个月前对比,与三年前对比,与五年前对比。都可以将数据抽取年月日(或者在设计数据库时候,定义年月日字段),使用窗口函数,实现单表查询,做数据分析。

复制代码
SELECT 	
    eqm_num,
    product_month,
    product_date,
    yyyy,
    mm,
    dd,
    today_all,
    today_ng,
    /*yesterday : 昨天*/
    yesterday_date,
    LAG(product_date,1)OVER(PARTITION BY  eqm_num ORDER BY product_date) AS yesterday,
    LAG(today_all,1)OVER(PARTITION BY  eqm_num ORDER BY product_date) AS yesterday_all,
    /*mm : 上个月*/
    last_month_date,
    LAG(product_date,1)OVER(PARTITION BY eqm_num, yyyy, dd ORDER BY mm) AS mm_day,
    LAG(today_all,1)OVER(PARTITION BY  eqm_num,yyyy, dd ORDER BY mm) AS mm_day_all,
    /*yyyy : 上一年*/
    last_year_date,
    LAG(product_date,1)OVER(PARTITION BY eqm_num, mm, dd ORDER BY yyyy) AS yyyy_day,
    LAG(today_all,1)OVER(PARTITION BY eqm_num, mm, dd ORDER BY yyyy) AS yyyy_day_all
FROM (
    /**/
    SELECT 
        product_month,
        product_date,
        DATEADD(YEAR, -1, product_date) AS last_year_date,
        DATEADD(MONTH, -1, product_date) AS last_month_date,
        DATEADD(DAY, -1, product_date) AS yesterday_date,
        YEAR(product_date) AS yyyy,
        MONTH(product_date) AS mm,
        DAY(product_date) AS dd,
        eqm_num,
        today_all,
        today_ng,
        deleted
    FROM dbo.tbl_daily
    WHERE deleted = 0
    /**/
)AS aa
WHERE deleted = 0
ORDER BY 
    eqm_num,
    product_date
相关推荐
hongtianzai5 分钟前
MySQL中between and的基本用法
android·数据库·mysql
隔壁小邓14 分钟前
数据库中间件全景解析:从连接管理到分布式协同
数据库·分布式·中间件
lcrml15 分钟前
Redis简介、常用命令及优化
数据库·redis·缓存
一只努力的微服务15 分钟前
【Calcite 系列】深入理解 Calcite 的 IntersectToSemiJoinRule
大数据·数据库·calcite·优化规则
todoitbo20 分钟前
从「亡羊补牢」到「规则先行」:金仓数据库 SQL 防火墙实战解析
数据库·sql·数据安全·防火墙·金仓数据库
艾莉丝努力练剑36 分钟前
【MYSQL】MYSQL学习的一大重点:数据库基础
linux·运维·服务器·数据库·c++·学习·mysql
I'mAlex38 分钟前
金仓数据库赋能北京一卡通:国产数据库在民生核心系统的信创实践标杆
数据库·kingbasees
xcLeigh38 分钟前
千日稳定守护,金仓数据库赋能北京一卡通斩获鼎信杯奖项
大数据·数据库·数据迁移·迁移·交通·金仓数据库·一卡通
猫猫bot43 分钟前
MySQL 登录报错 ERROR 1045:Access denied for user ‘root‘@‘localhost‘(using password: YES
数据库·mysql