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 杂谈

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