当前位置:网站首页 > Haskell函数式编程 > 正文

MySQL窗口函数(mysql窗口函数有哪些)



窗口函数有 over 关键字,指定函数执行的范围。可分为三部分:分组字句 (partition by),排序字句 (order by),滑动窗口字句 (rows)

 
  
 
   
cid(班级id) sname (学生姓名) score(分数) 001 张三 78 001 李四 82 002 小明 90 001 王五 67 002 小红 85 002 小刚 90

1.4.1 例1:查询各班级总分

 

在这里插入图片描述




1.4.2 例2:查询各班级累计总分

 

在这里插入图片描述




1.4.3 分区子句(partition by)

1.4.4 排序子句(order by)

1.4.5 窗口子句(rows)

语法概述:
① 起始行:N preceding / unbounded preceding
② 当前行:current row
③ 终止行:N following / unbounded following
举例:
① 从分区内的前面所有行到当前行:rows between unbounded preceding and current row
② 从分区内的前面 2 行到当前行:rows between 2 preceding and current row
③ 从分区内的当前行到后面所有行:rows between current row and unbounded following
④ 从分区内的当前行到后面 3 行:rows between current row and 3 following
注意:
① partition by 分区字句后,若 order 排序子句后缺少 rows 窗口子句,窗口规范默认为:rows between unbounded preceding and current row
② partition by 分区字句后, 若 order 排序子句和 rows 窗口子句都缺少,窗口规范默认为:rows between unbounded preceding and unbounded following





































1.4.6 总体执行流程

1.5.1 排序类函数

 

在这里插入图片描述




1.5.2 聚合类函数

1.5.3 跨行类函数

 

在这里插入图片描述




 
    
cid(班级id) sname (学生姓名) course(学科) score(分数) 001 张三 语文 78 002 小刚 语文 71 001 李四 数学 56 001 王五 数学 97 002 小明 数学 54 … … … …

题目 1:查询每个学生成绩最高的三个学科(分组内 Top N 问题)

 

在这里插入图片描述




题目 2:查询每个学科都高于班级学科平均分的学生(汇总分析问题)

 

在这里插入图片描述




 
     
empno ename hire_date salary dept_no 001 Adam 2018-03-01 1000 A 002 Bill 2021-03-01 1200 A 003 Cindy 2016-03-01 1500 A 004 Danney 2020-03-01 5000 A 005 Eason 2020-03-01 4000 B 006 Fred 2018-03-01 3500 B 007 Gary 2017-03-01 1800 B 008 Hugo 2020-03-01 4500 B



题目 1:查询每个部门工资最高的前三个员工信息(分组内 Top N 问题)

 

在这里插入图片描述




题目 2:查询员工工资占所属部门总工资的百分比(汇总分析问题)

 

在这里插入图片描述




题目 3:对各部门员工的工资进行升序排列,排名前 30% 为底层,30% - 80% 为中层,80% 以上为高层,并打上标签

 

在这里插入图片描述




题目 4:查询每年入职总数以及截至本年累计入职总人数(本年总入职人数 + 本年之前所有年的入职人数之和)

 

在这里插入图片描述




① 本文用窗口函数解决的 2 个主要问题:分区内 Top N 问题,汇总分析问题

② 分区内 Top N 公式

 

③ 窗口函数 → 生成辅助列(用于计算百分比等)

④ 重要:with 子句 → 生成临时表,把复杂的问题拆分成多个子问题,再用临时表表达

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








版权声明


相关文章:

  • pd.pivot函数(pivot函数 excel)2026-05-19 18:00:04
  • udp报文格式(UDP报文格式)2026-05-19 18:00:04
  • pd.pivot函数(pd.series函数)2026-05-19 18:00:04
  • mysql窗口函数row_number(mysql窗口函数排序)2026-05-19 18:00:04
  • 外贸支付方式有哪些(外贸支付方式有哪些种类)2026-05-19 18:00:04
  • udp广播模式发送指令(udp广播模式发送指令是什么)2026-05-19 18:00:04
  • 多级列表样式怎么设置(多级列表样式怎么设置第一章)2026-05-19 18:00:04
  • 反激电路公式(反激电路概念)2026-05-19 18:00:04
  • 聚合函数不能用在select(聚合函数不能用在什么语句中)2026-05-19 18:00:04
  • modbus报文实例(modbus协议报文格式)2026-05-19 18:00:04
  • 全屏图片