您的位置:首页 > 数据库

SQL笔记-ROW_NUMBER() OVER()函数

2018-01-22 14:52 357 查看
ROW_NUMBER() OVER()函数用来为每条记录返回一个行号,可以用来对记录进行排序并返回该序号,序号从1开始排序。

这里的over()是聚集函数,可以给记录进行分组、排序;row_number()不能单独使用,必须搭配over()才能使用,否则会报错。

简单地返回的行号

给student的每条记录进行排序并返回序号
select *, row_number() over() from student;


numclassnamerow_number
10001小明1
10012小白2
10022小黑3

给返回的行号起个别名

select *, row_number() over() rank from student;


numclassnamerank
10001小明1
10012小白2
10022小黑3

配合partition by/order by

给每个班的学生按照学号递减的顺序返回行号
select *, row_number() over(partition by class order by num desc) rank from student;


numclassnamerank
10001小明1
10022小黑1
10012小白2
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: