开窗函数MYSQL

在MySQL中,开窗函数允许你对一组行执行计算,并返回每个行的计算结果。这些函数对于执行复杂的分析操作非常有用,比如计算移动平均值、累计总和、行排名等。以下是对MySQL中一些常用开窗函数的细致讲解:

1. ROW_NUMBER()

`ROW_NUMBER()`为结果集中的每行分配一个唯一的序号,序号的分配是根据`OVER()`子句中指定的排序顺序决定的。如果存在相同的行,则序号会跳过重复的行。

**示例**:

```sql

SELECT

employee_id,

first_name,

last_name,

ROW_NUMBER() OVER (ORDER BY hire_date DESC) AS row_num

FROM

employees;

```

这个查询将根据`hire_date`降序排列员工,并为每个员工分配一个唯一的序号。

2. RANK() 和 DENSE_RANK()

`RANK()`和`DENSE_RANK()`用于对结果集中的行进行排名。`RANK()`在遇到并列排名时会跳过后续的序号(例如,如果两行并列第一,则下一个序号是第三),而`DENSE_RANK()`不会跳过,即使存在并列排名,序号也会连续。

**示例**:

```sql

SELECT

employee_id,

salary,

RANK() OVER (ORDER BY salary DESC) AS rank

FROM

employees;

```

这个查询将根据`salary`对员工进行排名。

3. NTILE()

`NTILE(n)`将结果集分为`n`个大致相等的组,并为每组分配一个组号。如果结果集中的行数不能被`n`整除,那么一些组将比其他组多一行。

**示例**:

```sql

SELECT

employee_id,

salary,

NTILE(4) OVER (ORDER BY salary DESC) AS quartile

FROM

employees;

```

这个查询将员工根据`salary`分为四个收入等级。

4. LEAD() 和 LAG()

`LEAD(column)`和`LAG(column)`允许你访问当前行之后的第n行(`LEAD`)或之前的第n行(`LAG`)的数据。如果不指定n,默认为1。

**示例**:

```sql

SELECT

current_salary,

LEAD(current_salary) OVER (ORDER BY employee_id) AS next_salary

FROM

employees;

```

这个查询将返回每行的当前薪资和下一行的薪资。

5. SUM() OVER()

使用`SUM()`开窗函数可以计算从结果集的开始到当前行的累积总和。

**示例**:

```sql

SELECT

employee_id,

salary,

SUM(salary) OVER (ORDER BY hire_date) AS cumulative_salary

FROM

employees;

```

这个查询将计算从`employees`表中最早入职的员工到当前员工的累计薪资。

6. AVG() OVER()

`AVG()`开窗函数可以计算从结果集的开始到当前行的滑动平均值。

**示例**:

```sql

SELECT

employee_id,

salary,

AVG(salary) OVER (ORDER BY hire_date ROWS BETWEEN 5 PRECEDING AND CURRENT ROW) AS moving_avg

FROM

employees;

```

这个查询将计算基于最近6个员工(包括当前员工)的薪资滑动平均值。

7. FIRST_VALUE() 和 LAST_VALUE()

`FIRST_VALUE()`和`LAST_VALUE()`分别返回窗口内第一行和最后一行的数据。

**示例**:

```sql

SELECT

employee_id,

hire_date,

FIRST_VALUE(hire_date) OVER (PARTITION BY department_id ORDER BY hire_date) AS first_hire_date

FROM

employees;

```

这个查询将为每个部门返回最早的入职日期。

注意事项

  • 开窗函数使用`PARTITION BY`子句来指定分组的列,这允许在每个分区内独立执行计算。

  • `ROWS BETWEEN ... AND ...`允许你指定窗口的边界,例如`ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING`表示当前行的前一行和后一行。

  • 开窗函数通常与`ORDER BY`子句结合使用,以定义计算的顺序。

开窗函数为MySQL提供了强大的数据分析能力,使得你可以在SQL查询中执行复杂的数据操作。

相关推荐
亿坊电商19 分钟前
PHP后端项目中多环境配置管理:开发、测试、生产的优雅解决方案!
服务器·数据库·php
韩立学长20 分钟前
基于Springboot的影视评论网站的设计与实现58py6238(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
未来之窗软件服务1 小时前
未来之窗昭和仙君(四十七)开发商品进销存——东方仙盟筑基期
数据库·进销存·仙盟创梦ide·东方仙盟·昭和仙君·东方仙盟架构
IDOlaoluo2 小时前
TinyRDM 1.2.3 Windows版安装教程(附Redis客户端下载及详细步骤)
数据库·redis·缓存
小光学长2 小时前
基于微信小程序的背单词系统x1o5sz72(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·微信小程序·小程序
我命由我123453 小时前
Derby - Derby 服务器(Derby 概述、Derby 服务器下载与启动、Derby 连接数据库与创建数据表、Derby 数据库操作)
java·运维·服务器·数据库·后端·java-ee·后端框架
RestCloud5 小时前
达梦数据库到Greenplum:用ETL工具实现数据仓库迁移
数据库·数据仓库·etl·达梦数据库·数据传输·greenplum
Boilermaker19926 小时前
【Redis】集群与分布式缓存
java·数据库·redis·1024程序员节
武子康6 小时前
Java-163 MongoDB 生产安全加固实战:10 分钟完成认证、最小权限、角色详解
java·数据库·分布式·mongodb·性能优化·系统架构·nosql
zhangyifang_0096 小时前
PostgreSQL 的表继承与分区
数据库·postgresql