mysql中的lead函数和over函数

文章目录

  • mysql中的lead函数和over函数
    • 作用
    • 需求场景
    • 实现方法
    • group by分组和使用over函数分组有什么区别?

mysql中的lead函数和over函数

作用

over函数是用来分组加排序的,然后等over函数分好组排好序之后,再使用lead函数去找当前分组内的下一行数据的某个字段值,具体是哪个字段由over函数指定,如果当前分组内没有下一条数据的话,那么返回null空值。

需求场景

我们有一个销售表,有很多类型的产品,我们想要根据产品id分组,然后再根据产品销售时间排序,我们想要显示下个月的销售额,以及下个月增加的销售额。

上面这个场景需求就是可以使用lead函数结合over函数来实现。

实现方法

首先看一下我们的销售表结构,如下图:
在这里插入图片描述
然后看一下里面我们存储的数据,如下图:
在这里插入图片描述
接着来看下我们执行的sql语句如下:

SELECT
    product_id,
    sales_date,
    sales_amount,
    LEAD(sales_amount) OVER (PARTITION BY product_id ORDER BY sales_date) AS next_sales_amount,
    (LEAD(sales_amount) OVER (PARTITION BY product_id ORDER BY sales_date) - sales_amount) AS growth_amount
FROM
    sales_data;

我们上面查询的时候追加了两个字段,一个是next_sales_amount,也就是分组内下一条数据的销售额;另外一个是growth_amount,也就是销售额增长量,也就是分组内下一条数据的销售额减去当前销售额;

over函数的功能:现根据product_id产品id进行分组,分组完之后又根据sales_date销售日期进行排序,然后取出当前行的销售额sales_amount;
lead函数的功能:取出当前分组的下一条数据的某个字段的值,如果当前分组内已经是最后一条数据了,那么会返回null。

上面的sql语句的执行结果,如下图:
在这里插入图片描述

group by分组和使用over函数分组有什么区别?

1.输出结果不同

  • over函数:over函数允许在不减少结果集行数的情况下添加聚合列。即每行都可以保留原有的列值的同时,增加额外的分析结果列,比如说下一条数据是多少,或者是下一条数据比起当前数据的增长额是多少。
  • group by子句:group by子句则将数据汇总为较少的行,每个分组只返回一行聚合结果,因此,它的输出行通常会比表的原始行数要少,适用于需要对数据进行高度汇总的情况。比如在student学生表中,计算每个班级的学生的平均分,这个使用group by子句先要根据班级id进行分组,然后再使用avg(score)聚合函数计算平均分,原始数据可能有540行,如果一个班级90人的话,那么使用group by之后的输出结果只会有6行,因为只有两个班级嘛!但是如果是使用over函数进行班级分组的话,那么输出结果行数仍会有540行。

2.适用场景不同

  • over函数:适用于需要同时查看原始行和聚合数据的场景,输出结果中不会少原始行,并且也会新增聚合数据。例如,在销售数据表中计算每个产品在连续月份中的销售额增长情况,可以使用lead函数结合over函数来实现。
  • group by子句:适用于需要对数据进行分组并汇总的场景。例如,计算每个部门的总薪水时,使用group by子句可以直接得到每个部门的薪水总和,而不显示每个员工的薪水详情。可能你的员工表的数据有1000行,但是公司只有36个部门,那么你的输出结果行数就只有36行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/729934.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

JMeter详解

一、线程组 作用:线程组就是控制Imeter用于执行测试的一组用户 位置:右键点击测试计划’-->添加 -->线程(用户)--> 线程组 特点: 模拟多人操作线程组可以添加多个,多个线程组可以并行或串行取样器(请求)和逻辑控制器必须依赖线程组才能使用线程组下可以…

自动化测试:Autorunner的使用

自动化测试:Autorunner的使用 一、实验目的 1、掌握自动化测试脚本的概念。 2、初步掌握Autorunner的使用 二、Autorunner的简单使用 autoRunner使用方法 新建项目 a) 在项目管理器空白区域,右键鼠标,选择新建项目 b) 输入项目名后,点击[确定]. 在初次打开aut…

手机怎么自动切换ip地址

在数字化时代,网络IP地址不仅是设备在网络世界的标识,也是确保用户网络安全和数据隐私的关键因素。对于手机用户来说,在某些情境下可能需要自动切换IP地址,本文将为您介绍手机怎么自动切换IP地址。 随着网络技术的发展&#xff0c…

python项目(课设)——飞机大战小游戏项目源码(pygame)

主程序 import pygame from plane_sprites import * class PlaneGame: """ 游戏类 """ def __init__(self): print("游戏初始化") # 初始化字体模块 pygame.font.init() # 创建游戏…

CocosCreator 微信小游戏上架流程准备工作

前言 事前准备非常重要,因为有creator的助力,实际上开发小游戏往往很快,但是如果准备不足,上架及审核过程非常慢,往往游戏做好了,还得各种排队等审核,大多数开发者又不是腾讯白名单之内&#x…

在WordPress上添加亚马逊联盟链接的三种方法

在互联网快速发展的今天,很多人都希望通过网络来增加收入,而加入亚马逊联盟计划(Amazon Associates)无疑是一个不错的选择。如果你有一个WordPress网站,那么在文章中添加亚马逊联盟链接是个很好的变现方式。今天&#…

什么样的企业适合运用裂变拉新工具?深入解析

在当今数字化快速发展的时代,裂变拉新工具已成为许多企业吸引新用户、扩大市场影响力的重要手段。然而,并非所有企业都适合运用这种工具。林叔将探讨哪些类型的企业更适合运用裂变拉新工具,并分析其背后的原因。 首先,拥有高度用…

DDK电通拧紧MFC-S060控制器过流维修

一、DDK伺服拧紧轴控制器过流故障的成因 1. 电源电压过低:当电源电压过低时,控制器可能会出现过流现象。 2. 负载过大:当负载过大时,DDK电通拧紧机控制器MFC-S060的电流也会随之增大,可能导致过流故障。 3. 控制器内部…

2024年7月JLPT日语N1真题试卷和答案解析,《Navi日语社》小程序在线答题考试,你的专属考试助手,日语学习神器!

掌握日语,从日语社小程序开始。这款小程序专为日语学习者设计,提供全面的JLPT备考资源,包括日语N1至N5等级考试的历年真题和2024年最新题目。无论你是日语新手还是备考高手,都能在这里找到适合自己的学习路径。 核心功能&#xf…

采购管理系统:反向竞价失败的 6 个常见原因

在当今快节奏和竞争激烈的商业环境中,采购专业人员一直在寻找创新战略来节约成本和简化供应链流程。反向竞价就是其中一种广受欢迎的策略。 反向竞价提供了一种独特的采购方法,允许买家邀请多个供应商参与实时竞标,以争取他们的业务。虽然反…

明基的台灯值得入手吗?书客、柏曼横向测评大比拼!

在当今社会,孩子们的学习负担日益加重,熬夜学习屡见不鲜,随之而来的是视力问题的凸显。中国青少年的近视率已位居世界前列,且地区间的近视率差异亦不容忽视。鉴于眼睛健康的重要性,选购一款优质的护眼台灯显得尤为重要…

vscode CMAKE 配置调试

概述 记录使用VSCODE中的CMAKE拓展构建项目时出现的报错 CMakePresets.json: {"version": 6,"configurePresets": [{"name": "x64-debug","displayName": "x64-debug","cmakeExecutable":…

1台SW工作站5人同时使用能实现吗

在当今的数字化时代,高效的工作方式和技术创新是企业竞争力的重要组成部分。SolidWorks作为一款功能强大的三维设计软件,广泛应用于机械、电子、建筑等多个领域。然而,随着企业规模的扩大和团队人数的增加,如何充分利用有限的资源…

如何将 ChatGPT 集成到你的应用中

在当今快速发展的技术环境中,将人工智能聊天解决方案集成到你的应用程序中可以显著提升用户体验和参与度。OpenAI 的 ChatGPT 以其对话能力和高级语言理解而闻名,对于希望在其应用程序中实现智能聊天功能的开发人员来说是一个绝佳的选择。那我们今天就来…

图片的格式怎样在线转换?在线改图片格式的操作技巧

图片作为日常生活中常用的内容展示方式,面对不同的用途图片的格式也是不同的,那么怎样快速完成图片格式转换呢?通过软件来修改图片格式比较麻烦,现在可以在网上使用图片格式转换器工具来在线改图片格式,这种方式会更加…

马斯克的Grok-1:开源AI模型的突破与挑战

在人工智能(AI)飞速发展的当下,xAI公司推出的最新作品Grok-1,不仅标志着技术的一大突破,也预示着AI领域的一次重大里程碑。这个经过四个月辛勤开发的模型,拥有高达3140亿参数的专家混合体系结构&#xff0c…

AI PPT生成器,一键在线智能生成PPT工具

PPT作为商业沟通和教育培训中的重要工具,PPT制作对于我们来说并不陌生。但是传统的PPT制作不仅耗时,而且想要做出精美的PPT,需要具备一定的设计技能。下面小编就来和大家分享几款AI PPT工具,只要输入主题,内容就可以在…

【R语言】对一个Plot绘制多个图,并且每个图单元也包含多个图

以一个Plot绘制五行六列共30个图&#xff0c;然后每30个图单元包含两个图为例&#xff1a; 如下图所示&#xff1a; 代码如下&#xff1a; for (i in 1:(5*6)) {create_subplots <- function() {library(ggplot2)library(dplyr)library(tidyr)# 创建一个随机的数据框simula…

IPD笔记

IPD笔记 先弄一个一图流&#xff0c;改天再过来继续补充 IPD&#xff08;Integrated Product Development&#xff09;即集成产品开发&#xff0c;是一套产品开发的模式、理念与方法。华为的IPD的核心思想是基于市场需求&#xff0c;将产品开发作为一项投资来管理&#xff0c;以…

灵活的招聘管理系统有五种方法帮助成功招聘

还记得以前的时代吗&#xff1f;这取决于你的年龄&#xff0c;直到智能手机、流媒体电视和电子邮件出现。今天&#xff0c;任何活着的成年人都经历了技术上的巨大变化&#xff0c;这创造了一种新的行为方式。人才获取也是如此。 一个值得推荐的招聘管理系统 招聘团队被困在满足…