【T-SQL系列】新的排序函数

如:ROW_NUMBER、RANK、DENSE_RANK
三个分析函数都是按照col1分组内从1开始排序

ROW_NUMBER() 是没有重复值的排序(即使两天记录相等也是不重复的),可以利用它来实现分页
DENSE_RANK() 是连续排序,两个第二名仍然跟着第三名
RANK() 是跳跃拍学,两个第二名下来就是第四名

示例:

DECLARE @t1 TABLE
    (
      Sequence INT ,
      Name VARCHAR(20) ,
      Score INT
    )

INSERT  INTO @t1
        SELECT  1 ,
                '' ,
                7
        UNION ALL
        SELECT  2 ,
                '' ,
                8
        UNION ALL
        SELECT  3 ,
                '' ,
                8
        UNION ALL
        SELECT  4 ,
                '' ,
                8
        UNION ALL
        SELECT  5 ,
                '' ,
                9
        UNION ALL
        SELECT  1 ,
                '' ,
                10
        UNION ALL
        SELECT  2 ,
                '' ,
                6
        UNION ALL
        SELECT  3 ,
                '' ,
                10
        UNION ALL
        SELECT  4 ,
                '' ,
                6
        UNION ALL
        SELECT  5 ,
                '' ,
                8

SELECT  Sequence ,
        Name ,
        Score ,
        ROW_NUMBER() OVER ( ORDER BY Sequence, Score ) AS RowNumber1 ,
        ROW_NUMBER() OVER ( ORDER BY Sequence, Score DESC ) AS RowNumber2 ,
        RANK() OVER ( ORDER BY Score ) AS Rnk ,
        DENSE_RANK() OVER ( ORDER BY Score ) AS DenseRnk ,
        NTILE(15) OVER ( ORDER BY Score ) AS Bucket
FROM    @t1

结果集:

转载于:https://www.cnblogs.com/Bobby0322/p/4082837.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值