實際上,row_number函數生成序號的基本原理是先使用over子句中的排序語句對記錄進行排序,然后按著這個順序生成序號。over子句中的order by子句與SQL語句中的order by子句沒有任何關系,這兩處的order by 可以完全不同,如下面的SQL語句所示:
select row_number() over(order by field2 desc) as row_number,* from t_table order by field1 desc 上面的SQL語句的查詢結果如圖3所示。
圖3
我們可以使用row_number函數來實現查詢表中指定范圍的記錄,一般將其應用到Web應用程序的分頁功能上。下面的SQL語句可以查詢t_table表中第2條和第3條記錄: with t_rowtable as ( select row_number() over(order by field1) as row_number,* from t_table ) select * from t_rowtable where row_number>1 and row_number < 4 order by field1
上面的SQL語句的查詢結果如圖4所示。
圖4
上面的SQL語句使用了CTE,關于CTE的介紹將讀者參閱《SQL Server2005雜談(1):使用公用表表達式(CTE)簡化嵌套SQL》。 另外要注意的是,如果將row_number函數用于分頁處理,over子句中的order by 與排序記錄的order by 應相同,否則生成的序號可能不是有續的。 當然,不使用row_number函數也可以實現查詢指定范圍的記錄,就是比較麻煩。一般的方法是使用顛倒Top來實現,例如,查詢t_table表中第2條和第3條記錄,可以先查出前3條記錄,然后將查詢出來的這三條記錄按倒序排序,再取前2條記錄,最后再將查出來的這2條記錄再按倒序排序,就是最終結果。SQL語句如下: select * from (select top 2 * from( select top 3 * from t_table order by field1) a order by field1 desc) b order by field1 上面的SQL語句查詢出來的結果如圖5所示。