知方可补不足~row_number,rank,dense_rank,ntile排名函数的用法
这篇文章介绍SQL中4个很有意思的函数,我称它的行标函数,它们是row_number,rank,dense_rank和ntile,下面分别进行介绍。
一 row_number:它为数据表加一个叫“行标示”的列,它在数据表中是连续的,我们必须按着某个顺序把表排序之后,才能使用row_number,看下列例子:
SELECT row_number() OVER ( ORDER BY SalePrice ) AS row , * FROM Product
结果表被加上了行号:
这个row_number在平常用的最多,它可以用来实现数据表的分页功能,看下面代码
SELECT * FROM ( SELECT row_number() OVER ( ORDER BY SalePrice ) AS row , * FROM Product ) AS Result WHERE Result.row BETWEEN 1 AND 2
它的含义是从第一条记录开始,取出2条记录,如果你想一页显示10条记录,可以使用BETWEEN 1 AND 10,如果想得到第二次的10条,那条件就变成BETWEEN 11 AND 20
二 rank:类型于row_number,不同之处在于,它会对order by 的字段进行处理,如果这个字段值相同,那么,行号保持不变,如代码:
SELECT RANK() OVER ( ORDER BY SalePrice ) AS row , SalePrice , ProductID , ProductName FROM Product
结果如下:
三 dense_rank:与rank类型,不同之处在于行号是否保留一个位置,rank对保留这个位置,即上面图中,row的值由1直接变为3,因为它的1出现了两次,所以为2保留了一个位置,而dense_rank不会保留2这个位置,即实现的行号2其实是排在了第3位,如代码:
SELECT DENSE_RANK() OVER ( ORDER BY SalePrice ) AS row , SalePrice , ProductID , ProductName FROM Product
结果如下:
四 ntile:为装桶操作,ntile(桶数)它在运行之前,先确定产生的桶数,然后根据桶数去生成行标,如代码:
SELECT NTILE(1) OVER ( ORDER BY SalePrice ) AS ntile , SalePrice , ProductID , ProductName FROM Product
结果如下:
如果设为NTILE(3),那结果就为:
当我们面对一个复杂的问题时,考验的不是你是否能解决,而是你采取哪种方式去解决以及代码的性能问题。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示