1. 程式人生 > >SQL Server之排序函數

SQL Server之排序函數

多條 數據分區 com log server2 窗函數 tro 原理 clas

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

技術分享

SQL Server之排序函數