当前位置:网站首页 > SQL数据库编程 > 正文

max开窗函数(MAX开窗函数用法SQL)



文章目录

  • 一 什么是窗口函数
  • 二 窗口函数实践
  • 2.1 统计成绩和排名
  • 2.2 销售统计
  • 计算累计销售额
  • 计算移动平均值
  • 计算排名
  • 计算百分比排名
  • 计算前后行的差值
  • 计算第一个和最后一个值

MySQL8 还是有很多重量级变化的,一些底层优化大家在使用中有时候不易察觉,但是有一些用法,还是带给我们耳目一新的感觉,今天松哥和大家分享一下 MySQL8 里边的窗口函数。

在 MySQL 8 中,窗口函数(Window Functions)是一类强大的分析函数,允许你在查询结果集上执行计算,而无需将数据分组到多个输出行中。窗口函数通常与 OVER() 子句一起使用,以指定数据窗口,即窗口函数将要在其上执行计算的行集。

简单来说,窗口函数的作用类似于在查询中对数据进行分组,不同的是,分组操作会把分组的结果聚合成一条记录,而窗口函数是将结果置于每一条数据记录中。

窗口函数的格式类似下面这样:

  • : 定义要在窗口中计算的聚合函数或其它分析函数,如 、、 等。
  • : 窗口函数的核心关键字。
  • : 定义要用来分组的一组列名。
  • : 定义用来排序的一组列名。
  • : 定义窗口的行集合。默认为 ,表示窗口包括从窗口开始到当前行的所有行。

接下来我们通过一个实际案例来体会下窗口函数。

假设我有如下一张表:

MySQL8 窗口函数是真的省事!_spring boot

我现在想要计算学生的考试总成绩以及单科成绩排名,利用窗口函数就能快速搞定,如下:

和窗口函数相关的就两列:

  • sum 求总分,over 中按照 name 进行分组,相当于就是计算每个人的总分。
  • dense_rank 是排序,这个函数会考虑并列的情况,但是并列并不影响排序,因为是计算每个人单科排名,所以就按照学科分组之后按照 score 排序。

最终执行结果如下:

MySQL8 窗口函数是真的省事!_数据_02

假设我有如下一张表:

MySQL8 窗口函数是真的省事!_java_03

这是一个名为 sales 的表,其中包含 id(销售记录 ID)、product_id(产品 ID)、sale_date(销售日期)和 amount(销售额)等字段。

现在有如下几个需求,大家把这几个需求搞懂了,基本上窗口函数就会用了。

计算累计销售额

需求:按产品 ID 分组,计算每个产品的累计销售额。

表示按 product_id 分组,按 sale_date 排序,计算每个产品的累计销售额。

最终查询结果如下:

MySQL8 窗口函数是真的省事!_窗口函数_04

计算移动平均值

需求:按产品 ID 分组,计算每个产品的最近 3 笔销售记录的移动平均销售额。

表示按 分组,按 排序,计算当前行及前两行的平均销售额。

最终查询结果如下:

MySQL8 窗口函数是真的省事!_java_05

计算排名

需求:按产品 ID 分组,计算每个销售记录在该产品中的排名。

表示按 product_id 分组,按 amount 降序排序,计算每个销售记录在该产品中的排名。

最终查询结果如下:

MySQL8 窗口函数是真的省事!_窗口函数_06

计算百分比排名

需求:按产品 ID 分组,计算每个销售记录在该产品中的百分比排名。

表示按 product_id 分组,按 amount 降序排序,计算每个销售记录在该产品中的百分比排名。

最终查询结果如下:

MySQL8 窗口函数是真的省事!_java_07

计算前后行的差值

需求:按产品 ID 分组,计算每个销售记录与上一个销售记录之间的销售额差值。

最终查询结果如下:

MySQL8 窗口函数是真的省事!_分析函数_08

计算第一个和最后一个值

需求:按产品 ID 分组,计算每个产品的第一个和最后一个销售日期。

最终查询结果如下:

MySQL8 窗口函数是真的省事!_数据_09

好啦,通过这几个小小案例,小伙伴们明白窗口函数了吧~

到此这篇max开窗函数(MAX开窗函数用法SQL)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • msvcp140.dll丢失的解决方法 mysql(msvcp140.dll丢失的解决方法没有网可解决吗)2025-06-10 13:27:10
  • sql的循环语句怎么用(sql里循环怎么用)2025-06-10 13:27:10
  • sql文件是什么类型(sql文件是什么类型格式)2025-06-10 13:27:10
  • oracle sql 最大长度(oracle sql语句最大长度)2025-06-10 13:27:10
  • oracle查看锁表SQL(如何查看oracle数据库锁表)2025-06-10 13:27:10
  • sql增删改查(SQL增删改查语句百度百科)2025-06-10 13:27:10
  • 安装pymysql包的命令(pymysql安装包下载)2025-06-10 13:27:10
  • sql server数据库文件格式(sql server 数据文件)2025-06-10 13:27:10
  • sql文件转json(sql文件转换)2025-06-10 13:27:10
  • sql循环语句的作用是什么(sqlserver循环语句)2025-06-10 13:27:10
  • 全屏图片