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

devtools/2024/9/23 15:52:16/

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,deletedFROM dbo.tbl_dailyWHERE deleted = 0/**/
)AS aa
WHERE deleted = 0
ORDER BY eqm_num,product_date

 


http://www.ppmy.cn/devtools/56362.html

相关文章

回溯法基本思想-01背包、N皇后回溯法图解

基本思想: ​ 回溯法是一种系统地搜索问题解空间的算法,常用于解决组合优化和约束满足问题。其核心思想是利用深度优先搜索逐步构建可能的解,同时在搜索过程中进行剪枝操作,以排除那些无法满足问题约束或不能产生最优解的分支&am…

可持续发展教育:塑造未来的教育模式

在当今全球化和技术进步的背景下,可持续发展教育(Education for Sustainable Development, ESD)正逐渐成为教育改革的重要议题。本文将深入探讨可持续发展教育的定义、重要性、实施策略及其在全球教育中的实际影响,旨在为读者提供…

【数据科学】学习资源汇总(不定时更新)

好书推荐:BooksPDF/数据科学/Python数据科学手册.pdf at master zhixingchou/BooksPDF GitHub

Qt第十章设计师

Designer设计师的使用 本文图片资源已上传 文章目录 Designer设计师的使用1.创建带UI文件的项目2.UI设计器使用3.自定义控件1. 通过控件提升,可以实现自定义控件2. 新建自定义控件1. 新建项目2. 添加代码3.生成动态库 2.DLL文件使用1. QtCreator使用DLL 注意要查看…

mysql安装配置教程

mysql安装配置教程 MySQL是一个流行的关系型数据库管理系统,用于存储和管理数据。下面是简要的MySQL安装配置教程: 步骤1:下载MySQL 访问MySQL官方网站(https://dev.mysql.com/downloads/mysql/)下载适合您操作系统…

CSS列表属性:list-style系列属性详解

CSS(层叠样式表)是用于控制网页样式的一种语言,它允许开发者以一种非常灵活的方式来设置网页元素的外观。在CSS中,list-style属性族是专门用来设置列表样式的。列表是网页设计中常见的元素,它们可以是有序列表&#xf…

【LeetCode】每日一题:验证回文字符串

如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。 字母和数字都属于字母数字字符。 给你一个字符串 s,如果它是 回文串 ,返回 true ;否则&#xf…

Deep Learning复习笔记0

Key Concept: Embedding: learned dense, continuous, low-dimensional representations of object 【将难以表示的对象(如图片,文本等)用连续的低维度的方式表示】 RNN: Recurrent Neural Network -> for processing sequential data (time series data, natur…