Sql Server2005資料庫自帶一個排序函數ROW_NUMBER(),列表為: 語法:row_number() : over(子句)1.使用row_number()函數進行編號: 原理:先按Sage進行排序,排序完後,給每條數據進行編號。註:在使用over等開窗函數時,over裡頭的分組及排序 ...
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是數據分區取數,用於給結果集分組,如果沒有指定那麼它把整個結果集作為一個分組;
它和聚合函數不同的地方在於它能返回一個分組中的多條記錄,而聚合函數一般只有一條反映統計值的記錄。
原理:統計出不同性別的學生數並按每一個學生的年齡排序,同時給每一個學生進行編號。這樣就知道男生和女生的個數。
結果: