SQL中row_number()?over(partition?by)的用法說明
row_number 語法
ROW_NUMBER()函數(shù)將針對SELECT語句返回的每一行,從1開始編號,賦予其連續(xù)的編號。在查詢時應(yīng)用了一個排序標(biāo)準(zhǔn)后,只有通過編號才能夠保證其順序是一致的,當(dāng)使用ROW_NUMBER函數(shù)時,也需要專門一列用于預(yù)先排序以便于進(jìn)行編號
partition by關(guān)鍵字是分析性函數(shù)的一部分,它和聚合函數(shù)不同的地方在于它能返回一個分組中的多條記錄,而聚合函數(shù)一般只有一條反映統(tǒng)計值的記錄,partition by用于給結(jié)果集分組,如果沒有指定那么它把整個結(jié)果集作為一個分組,分區(qū)函數(shù)一般與排名函數(shù)一起使用。
原始表score
s_id 表是學(xué)生編號,c_id表是課程編號,s_score 表是學(xué)生對應(yīng)的課程分?jǐn)?shù)

1.要求:得出每門課程的學(xué)生成績排序(升序)
----因為是每門課程的結(jié)果,并且要排序,所以用row_number
select * ,row_number() over (partition by c_id order by s_score) from score;
返回結(jié)果:

2:進(jìn)一步要求:得出每門課程的學(xué)生成績,并且按照70分作為分割線排序—即低于70分的排序,高于70分的排序
select * ,row_number() over (partition by c_id,(case when s_score>70 then 1 else 0 end) order by s_score) from score;
返回結(jié)果:

row_number() over(partition by 列名1 order by 列名2 desc)的使用
表示根據(jù) 列名1 分組,然后在分組內(nèi)部根據(jù) 列名2 排序,而此函數(shù)計算的值就表示每組內(nèi)部排序后的順序編號,可以用于去重復(fù)值
與rownum的區(qū)別在于:使用rownum進(jìn)行排序的時候是先對結(jié)果集加入偽列rownum然后再進(jìn)行排序,而此函數(shù)在包含排序從句后是先排序再計算行號碼.
---查詢所有姓名,如果同名,則按年齡降序
SELECT?name,age,detail,ROW_NUMBER()?OVER(PARTITION?BY?name?ORDER?BY?age?DESC)?FROM?TEST_Y;

通過上面的語句可知,是按照name字段分組,按age字段排序的。
如果只需查詢出不重復(fù)的姓名即可,則可使用如下的語句, 由查詢結(jié)果可知,姓名相同年齡小的數(shù)據(jù)被過濾掉了;
SELECT ? * ? FROM ? ( SELECT ? name ,age, detail ,ROW_NUMBER() ? OVER ( ? PARTITION ? BY ? name? ORDER ? BY ? age? DESC )RN ? FROM ? TEST_Y ) WHERE ? RN= ? 1 ;

分頁
--先做一個子查詢,先按id1進(jìn)行排序,排序完后,給每條記錄進(jìn)行了編號
--然后再將子查詢做為一張表,就可以進(jìn)行分頁了
select * ? from (select t.*,row_number() over(order by t.id1 asc) as rn from demo t) d ? where d.rn between 1 and 2
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
- 使用row_number()實現(xiàn)分頁實例
- oracle中rownum和row_number()
- 利用ROW_NUMBER() OVER函數(shù)給SQL數(shù)據(jù)庫中每一條記錄分配行號的方法
- Mysql row number()排序函數(shù)的用法和注意
- SQL中distinct 和 row_number() over() 的區(qū)別及用法
- MYSQL row_number()與over()函數(shù)用法詳解
- SQL使用ROW_NUMBER() OVER函數(shù)生成序列號
- MySQL中rank() over、dense_rank() over、row_number() over用法介紹
- Row_number()函數(shù)用法小結(jié)
- 數(shù)據(jù)庫中row_number()?分組排序函數(shù)的具體使用
相關(guān)文章
本文主要給大家通過一個實例來具體介紹MySQL死鎖問題的相關(guān)知識,接下來我們就來一一介紹這部分內(nèi)容,希望能夠?qū)δ兴鶐椭?/div> 2016-11-11
MySql子查詢IN的執(zhí)行和優(yōu)化的實現(xiàn)
本文主要介紹了MySql子查詢IN的執(zhí)行和優(yōu)化的實現(xiàn),詳細(xì)的介紹了為什么IN這么慢以及如何優(yōu)化,具有一定的參考價值,感興趣的可以了解一下2021-07-07
解決mysql ERROR 1017:Can''t find file: ''/xxx.frm'' 錯誤
如果重啟服務(wù)器前沒有關(guān)閉mysql,MySql的MyiSAM表很有可能會出現(xiàn) ERROR #1017 :Can't find file: '/xxx.frm' 的錯誤2011-08-08
深入研究mysql中的varchar和limit(容易被忽略的知識)
這篇文章主要介紹了深入研究mysql中的varchar和limit(容易被忽略的知識),本文探究了varchar(5)可以存儲多少個漢字、多少個字母數(shù)字和mysql中的limit你真的會用嗎兩個知識點,需要的朋友可以參考下2015-03-03
簡單解決Windows中MySQL的中文亂碼與服務(wù)啟動問題
這篇文章主要介紹了Windows中MySQL的中文亂碼與服務(wù)啟動問題,如果程序沒有特殊需要則建議MySQL盡量默認(rèn)設(shè)為UTF-8格式編碼,需要的朋友可以參考下2016-03-03
MybatisPlus攔截器如何實現(xiàn)數(shù)據(jù)表分表
為了解決MySQL中大數(shù)據(jù)量的查詢效率問題,采用水平拆分策略,通過取模運(yùn)算確定表后綴,實現(xiàn)數(shù)據(jù)的有效管理,設(shè)計分表時,需利用線程變量存取請求參數(shù),并通過攔截器確定操作的具體表名,從而優(yōu)化數(shù)據(jù)處理性能,此方法適用于業(yè)務(wù)表數(shù)據(jù)量大或快速增長的場景2024-11-11最新評論

