sql中rownumber的用法-SQL

SQL 中 ROWNUMBER 函数的使用

ROWNUMBER 函数介绍

ROWNUMBER 函数是一个内置函数,用于为表中的每一行生成唯一的行号。它的语法如下:

ROWNUMBER([OVER (PARTITION BY [partition_expression] ORDER BY [order_expression])] OVER (ORDER BY [order_expression]))
登录后复制

参数说明

  • PARTITION BY: 指定用于分区的数据列。
  • ORDER BY: 指定排序数据行的顺序。
  • OVER: 指定对哪些行应用 ROWNUMBER 函数。

用法

1. 为表中的每一行生成行号:

SELECT ROWNUMBER() OVER (ORDER BY id) AS RowNum, * FROM table_name;
登录后复制

2. 按分区生成行号:

SELECT ROWNUMBER() OVER (PARTITION BY department_id ORDER BY salary) AS RowNum, * FROM employee_table;
登录后复制

3. 为特定行集合生成行号:

SELECT ROWNUMBER() OVER (ORDER BY salary) AS RowNum, * 
FROM employee_table
WHERE department_id = 10;
登录后复制

4. 指定行号起始值:

SELECT ROWNUMBER(10) OVER (ORDER BY id) AS RowNum, * FROM table_name;
登录后复制

注意事项

  • ROWNUMBER 函数不能用于计算聚集函数,例如 SUM() 或 AVG()。
  • ROWNUMBER 函数只适用于 SELECT 语句。
  • ROWNUMBER 是一个非确定性函数,这意味着每次查询执行时它可能生成不同的行号。

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。