mysql 中 row_number() over partition by 这个函数什么意思
时间: 2023-10-12 17:16:21 浏览: 192
row_number,根据多个字段过滤,partition by
在 MySQL 中,ROW_NUMBER() OVER (PARTITION BY ...) 函数用于为每个分区中的行分配一个唯一的序号。它的语法类似于在其他数据库中使用的语法,如 Oracle 和 SQL Server。
PARTITION BY 子句用于指定分区列或表达式。在每个分区中,ROW_NUMBER() 函数将为每个行分配一个唯一的序号,这些行具有相同的分区值。序号从 1 开始递增,直到分区中的最后一行。
例如,以下查询使用 ROW_NUMBER() OVER (PARTITION BY department_id ORDER BY salary DESC) 函数为每个部门中工资最高的员工分配一个唯一的序号:
```
SELECT employee_id, department_id, salary, ROW_NUMBER() OVER (PARTITION BY department_id ORDER BY salary DESC) as rank
FROM employees;
```
这将返回一个结果集,其中每个行都包含员工的 ID、部门 ID、薪水和在其所属部门中的排名。
阅读全文