SQL Server之排序函數


Sql Server2005數據庫自帶一個排序函數ROW_NUMBER()
列表為:


語法:row_number() : over(子句)
1.使用row_number()函數進行編號:

select row_number() over(order by Sage) id ,* from Student

原理:先按Sage進行排序,排序完后,給每條數據進行編號。
注:在使用over等開窗函數時,over里頭的分組及排序的執行晚於“where,group by,order by”的執行。
結果為:


2.使用row_number()函數進行統計:

select row_number() over(partition by Ssex order by Sage) as rows,* from Student

注:partition by是數據分區取數,用於給結果集分組,如果沒有指定那么它把整個結果集作為一個分組;
它和聚合函數不同的地方在於它能返回一個分組中的多條記錄,而聚合函數一般只有一條反映統計值的記錄。
原理:統計出不同性別的學生數並按每一個學生的年齡排序,同時給每一個學生進行編號。這樣就知道男生和女生的個數。
結果:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM