SQL中四大排序函数

以这个表为例,解释四大排序函数的区别。

idnum
12
23
36
44
510
64

1.ROW_NUMBER():

在排序的时候,ROW_NUMBER():按照指定的顺序排序,为每一行分配一个连续的、唯一的整数值,这意味着即使有相同的排序值,每行的排名也是唯一的。

select *,row_number() OVER(order by num ) as row_num
from num

结果如下(注意num相同的值,row_num值不一样)

idnumrow_num
121
232
443
644
365
5106


2.RANK()

rank函数是排名函数。rank函数最常用的是求某一个数值在某一区域的排名。即返回一个数字的排位是其大小与列表中其他值的比值,如果列表已排过序,则数字的排位就是它当前的位置。

select *,rank() OVER(order by num ) as row_num
from num

结果如下,注意num相同的值,row_num一样,但是不影响接下来排序,如下row_num两个3后面直接是5,即排名是不连续的。

idnumrow_num
121
232
443
643
365
5106

3.DENSE_RANK()

RENSE_RANK()函数排名连续,不会跳过相同的值的行。也就是具有多个相同的值,会被分配相同的排名,后面的排名紧接排名后面,不会跳过相同值的函数。

select *,DENSE_RANK() OVER(order by num ) as row_num
from num

结果如下和RANK()很像,但是排名连续

idnumrow_num
121
232
443
663
364
5105

4.NTILE()

NTILE()比较特殊,NTILE(group_num)将结果集分成group_num个组,并为每一个组分配一个序号,使得每个组的行数尽可能平均,如果行数不能被group_num整除,则前几个组的行数将比后面的组多一个。NTILE() 返回的序号从1到group_num。

select *,NTILE(3) OVER(order by num ) as row_num
from num

结果如下,把这个排序后的数平均分成了三组。

idnumrow_num
121
231
442
642
363
5103

这就是这四个排序函数的基本区别,学习任重而道远,咱们一起加油。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值