1.rank() over():
查出指定条件后的进行排名。特点是,加入是对学生排名,使用这个函数,成绩相同的两名是并列,下一位同学空出所占的名次。
Select name,subject,score,rank() over(partition by subject order by score desc) rank from student_score;
2.dense_rank() over():
与rank() over() 的区别是:两名学生的成绩并列以后,下一位同学并不空出所占的名次。
Select name,subject,score,dense_rank() over(partition by subject order by score desc) rank from student_score;
3.row_number() over():
这个函数不考虑是否并列,哪怕根据条件查询处理的数值相同也会进行连续排名。
Select name,subject,score,row_number() over(partition by subject order by score desc) rank from student_score;