日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

今天給大家介紹一下SQL Server排名中經(jīng)常用到的ROW_NUMBER(),RANK(),DENSE_RANK(),NTILE()這四個好兄弟。

 

我們先創(chuàng)建一個測試數(shù)據(jù)表Scores

WITH t AS
(SELECT 1 StuID,70 Score
UNION ALL
SELECT 2,85
UNION ALL
SELECT 3,85
UNION ALL
SELECT 4,80
UNION ALL
SELECT 5,74
)
SELECT * INTO Scores FROM t;
SELECT * FROM Scores

結(jié)果如下:

聊聊SQL中的排名問題圖片

 

1、ROW_NUMBER()

定義:ROW_NUMBER()函數(shù)作用就是將SELECT查詢到的數(shù)據(jù)進行排序,每一條數(shù)據(jù)加一個序號,他不能用做于學(xué)生成績的排名,一般多用于分頁查詢,比如查詢前10個 查詢10-100個學(xué)生。 

 

1.1 對學(xué)生成績排序

示例

SELECT
ROW_NUMBER() OVER (ORDER BY SCORE DESC) AS [RANK],*
FROM Scores;

結(jié)果如下:

聊聊SQL中的排名問題圖片

這里RANK就是每個學(xué)生的排名后的次序, 根據(jù)Score進行DESC倒序 

 

1.2 獲取第2名的成績信息 

SELECT * FROM (
SELECT ROW_NUMBER() OVER (ORDER BY SCORE DESC) AS [RANK],*
FROM Scores
) t WHERE t.RANK=2;

結(jié)果:

聊聊SQL中的排名問題圖片

這里用到的思想就是 分頁查詢的思想 在原sql外再套一層SELECTWHERE t.RANK>=1 AND t.RANK<=3 是不是就是獲取前三名學(xué)生的成績信息了。

 

2、RANK() 

定義:RANK()函數(shù),顧名思義排名函數(shù),可以對某一個字段進行排名,這里和ROW_NUMBER()有什么不一樣呢?ROW_NUMBER()是排序,當存在相同成績的學(xué)生時,ROW_NUMBER()會依次進行排序,他們序號不相同,而Rank()則不一樣。如果出現(xiàn)相同的,他們的排名是一樣的。下面看例子:

 

示例

SELECT ROW_NUMBER() OVER (ORDER BY SCORE DESC) AS [RANK],*FROM Scores;SELECT RANK() OVER (ORDER BY SCORE DESC) AS [RANK],*FROM Scores;

結(jié)果:

聊聊SQL中的排名問題圖片

上面是ROW_NUMBER()函數(shù)的結(jié)果,下面是RANK()函數(shù)的結(jié)果。

當出現(xiàn)兩個學(xué)生成績相同是里面出現(xiàn)變化。RANK()是1-1-3-4-5,而ROW_NUMBER()則還是1-2-3-4-5,這就是RANK()和ROW_NUMBER()的區(qū)別了

 

3、DENSE_RANK() 

定義:DENSE_RANK()函數(shù)也是排名函數(shù),和RANK()功能相似,也是對字段進行排名,那它和RANK()到底有什么不同那?特別是對于有成績相同的情況,DENSE_RANK()排名是連續(xù)的,RANK()是跳躍的排名,一般情況下用的排名函數(shù)就是RANK() 我們看例子:

 

示例

SELECTRANK() OVER (ORDER BY SCORE DESC) AS [RANK],*FROM Scores;SELECTDENSE_RANK() OVER (ORDER BY SCORE DESC) AS [RANK],*FROM Scores;

結(jié)果:

聊聊SQL中的排名問題

上面是RANK()的結(jié)果,下面是DENSE_RANK()的結(jié)果

 

4、NTILE()

定義:NTILE()函數(shù)是將有序分區(qū)中的行分發(fā)到指定數(shù)目的組中,各個組有編號,編號從1開始,就像我們說的'分區(qū)'一樣 ,分為幾個區(qū),一個區(qū)會有多少個。  

SELECT NTILE(1) OVER (ORDER BY SCORE DESC) AS [RANK],* FROM Scores;

SELECT NTILE(2) OVER (ORDER BY SCORE DESC) AS [RANK],* FROM Scores;

SELECT NTILE(3) OVER (ORDER BY SCORE DESC) AS [RANK],* FROM Scores;

結(jié)果:

聊聊SQL中的排名問題圖片

就是將查詢出來的記錄根據(jù)NTILE函數(shù)里的參數(shù)進行平分分區(qū)。

這幾兄弟就介紹完了,有空再給大家介紹分組排名的問題。

分享到:
標簽:SQL
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運動步數(shù)有氧達人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定