【重学MySQL】八十九、窗口函数的分类和使用

【重学MySQL】八十九、窗口函数的分类和使用

一、窗口函数分类

1. 聚合类窗口函数

  • SUM():计算窗口内数值总和
  • AVG():计算窗口内数值平均值
  • COUNT():统计窗口内行数
  • MAX()/MIN():获取窗口内最大/最小值

2. 排名类窗口函数

  • ROW_NUMBER():生成唯一行号(1,2,3...)
  • RANK():允许并列的排名(1,1,3...)
  • DENSE_RANK():密集排名(1,1,2...)
  • NTILE(n):将数据分为n个桶

3. 分布类窗口函数

  • PERCENT_RANK():计算百分比排名
  • CUME_DIST():计算累积分布

4. 前后行类窗口函数

  • LAG(col, n):获取前n行数据
  • LEAD(col, n):获取后n行数据

5. 头尾函数

  • FIRST_VALUE(col):获取窗口首行值
  • LAST_VALUE(col):获取窗口末行值

二、窗口函数语法

sql 复制代码
函数名() OVER (
  [PARTITION BY 分组字段]
  [ORDER BY 排序字段 [ASC|DESC]]
  [frame_clause]
)
  • PARTITION BY:将结果集拆成多个分区,各自独立计算。
  • ORDER BY:决定窗口内的顺序。
  • ROWS|RANGE:限定窗口的物理/逻辑边界。

三、典型使用场景

场景1:分组聚合

sql 复制代码
-- 计算每个部门的平均工资
SELECT 
  name,
  department,
  salary,
  AVG(salary) OVER (PARTITION BY department) AS dept_avg_salary
FROM employees;

场景2:排名计算

sql 复制代码
-- 按成绩降序排名(允许并列)
SELECT 
  student_id,
  score,
  RANK() OVER (ORDER BY score DESC) AS ranking
FROM exam_results;

场景3:移动平均

sql 复制代码
-- 计算3天移动平均温度
SELECT 
  date,
  temperature,
  AVG(temperature) OVER (
    ORDER BY date 
    ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING
  ) AS moving_avg
FROM weather_data;

场景4:前后值对比

sql 复制代码
-- 对比本月与上月销售额
SELECT 
  month,
  sales,
  LAG(sales, 1) OVER (ORDER BY month) AS prev_month_sales,
  sales - LAG(sales, 1) OVER (ORDER BY month) AS growth
FROM monthly_sales;

四、高级技巧

  1. 多级排序PARTITION BY + ORDER BY 组合使用
  2. 窗口框架控制 :使用 ROWS/RANGE 定义精确计算范围
  3. 命名窗口 :通过 WINDOW 子句复用窗口定义

窗口函数在OLAP分析、趋势计算、异常检测等场景中表现优异,可显著简化复杂查询逻辑。

相关推荐
摩羯座-185690305948 小时前
爬坑 10 年!京东店铺全量商品接口实战开发:从分页优化、SKU 关联到数据完整性闭环
linux·网络·数据库·windows·爬虫·python
编程充电站pro9 小时前
SQL 面试高频:INNER JOIN vs LEFT JOIN 怎么考?
数据库·sql
这周也會开心9 小时前
SQL-窗口函数做题总结
数据库·sql
间彧10 小时前
TiDB详解与Spring Boot实战指南
数据库
极限实验室10 小时前
Easysearch 字段'隐身'之谜:source_reuse 与 ignore_above 的陷阱解析
数据库·redis
2301_7720935610 小时前
tuchuang_后端_前端_注册登录
数据库·后端·网络协议·mysql·wireshark
K_i13410 小时前
中国电信用户行为实时分析系统运维实战
hadoop·mysql
武子康10 小时前
Java-141 深入浅出 MySQL Spring事务失效的常见场景与解决方案详解(3)
java·数据库·mysql·spring·性能优化·系统架构·事务
间彧10 小时前
脏读、不可重复读、幻读详解与对比
数据库
间彧10 小时前
数据库事务隔离级别详解
数据库