WEB开发网      濠靛倻鏅悵顖涚附閽樺鐎诲ù婊庡亾缁辨帗鎷呴悩鍨暠濞戞挴鍋撳ù鐘烘閸ㄥ孩绂嶉锝喰﹂柟瀛樺灣濠婃垿鎯冮崟顏嗩伇濞寸姾妫勬慨鈺呭礉濞戝磭骞㈤悹鍥у槻閸ㄥ孩绂嶉敓锟� ---闁挎洩鎷�
开发学院数据库MSSQL Server SQL Server2005杂谈(3):四个排名函数(row_num... 阅读

SQL Server2005杂谈(3):四个排名函数(row_number、rank、dense_rank和ntile)的比较

 2009-02-06 10:20:49 来源:WEB开发网 闁靛棴鎷�闁告垵绻愰惃顒傗偓娑欍仦缂嶏拷濠⒀呭仜閵囧洨鈧稒銇炵紞锟�闁靛棴鎷�  闁稿繗娅曢弫鐐垫嫬闁垮鈧秹鏌ㄧ€靛憡鐣辩€甸偊鍠栧畷锟�
核心提示: selectrow_number()over(orderbyfield2desc)asrow_number,*fromt_tableorderbyfield1desc上面的SQL语句的查询结果如图3所示,图3我们可以使用row_number函数来实现查询表中指定范围的记录,SQL Serv

selectrow_number()over(orderbyfield2desc)asrow_number,*fromt_tableorderbyfield1desc

上面的SQL语句的查询结果如图3所示。

SQL Server2005杂谈(3):四个排名函数(row_number、rank、dense_rank和ntile)的比较

图3

我们可以使用row_number函数来实现查询表中指定范围的记录,一般将其应用到Web应用程序的分页功能上。下面的SQL语句可以查询t_table表中第2条和第3条记录:

witht_rowtable
as
(
  selectrow_number()over(orderbyfield1)asrow_number,*fromt_table
)
select*fromt_rowtablewhererow_number>1androw_number<4orderbyfield1

上面的SQL语句的查询结果如图4所示。

SQL Server2005杂谈(3):四个排名函数(row_number、rank、dense_rank和ntile)的比较

图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语句如下:

上一页  1 2 3 4 5  下一页

Tags:SQL Server 杂谈

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接