使用 MySQL 窗口函数的步骤:1. 定义窗口(OVER 关键字)、2. 选择窗口函数(SUM()、AVG()、RANK())、3. 应用窗口函数。窗口函数类型有分组、排序、行、累计。窗口范围指定窗口内行数(ROWS BETWEEN)或行值范围(RANGE BETWEEN),或从起始行到当前行(UNBOUNDED PRECEDING)或从当前行到最后(UNBOUNDED FOLLOWING)。
如何使用 MySQL 中的窗口函数
窗口函数是 SQL 中用于对数据集内行数据进行聚合计算的函数。它们在窗口内进行操作,窗口由行值之间的特定顺序或分组定义。
如何使用窗口函数
使用窗口函数需要三个步骤:
OVER 关键字定义窗口,它指定窗口的范围和排序顺序。SUM()、AVG() 或 `RANK()”。窗口函数示例
以下示例演示如何使用 SUM() 窗口函数计算每个组内的行总和:
SELECT department_id,
SUM(salary) OVER (PARTITION BY department_id) AS total_salary
FROM employee;窗口函数类型
MySQL 中有四种主要的窗口函数类型:
SUM() 和 `AVG()”。RANK() 和 `DENSE_RANK()”。LAG() 和 `LEAD()”。
SUM() 和 AVG() 的 OVER (ORDER BY .. ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW)。窗口范围
窗口范围指定窗口中要包括的行,可以是:
ROWS BETWEEN 3 PRECEDING AND 3 FOLLOWING。RANGE BETWEEN INTERVAL 1 DAY PRECEDING AND INTERVAL 1 DAY FOLLOWING。UNBOUNDED PRECEDING)或从当前行到最后(UNBOUNDED FOLLOWING)。注意:
GROUP BY、HAVING 或 DISTINCT 语句一起使用。