排序函数rank()

rank()

含义:

RANK()函数是一个Window函数,它为结果集的分区中的每一行分配一个排名。分区中具有相同值的行将获得相同的排名。
分区中第一行的等级是1。 RANK()函数将绑定行的数量添加到绑定等级以计算下一行的等级,因此,等级可能不是连续的。

语法:

RANK() OVER (
    [PARTITION BY partition_expression, ... ]
    ORDER BY sort_expression [ASC | DESC], ...)

PARTITION BY 分组,ORDER BY排序

举例:
学生成绩表如下:

利用rank()函数,按每门课程成绩的高低排序,sql如下:

select rank() over(partition by gc_no order by gs_scoure desc)a,* from test.[dbo].[grade]

结果如下:
在这里插入图片描述
从结果可以看出:
一、相同的成绩,排名是相同的,之后的排名是不连续的,按照行的数量继续进行编号的。
二、不同的分组,排名是重新从1开始的。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值