T-SQL利用Row_Number函数实现分页
            时间:2014-05-14 13:15:07  
            收藏:0  
            阅读:473
        
        
        SQL:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | CREATEPROCEDUREPagingViewTest(   @currentPageIndex INT, --页序号   @pageSize INT, --页大小   @pageCount INTOUTPUT--返回值,总记录数)ASBEGIN<br>--取总记录数SELECT@pageCount=COUNT(OrderID) FROMdbo.sale_Order;--利用CTE以提高执行效率WITHResultAS(   SELECTROW_NUMBER() OVER(ORDERBYOrderID) ASrowNumber,* FROMsale_order s)SELECT* FROMResult r WHERE((@currentPageIndex-1)*@pageSize < rowNumber)   AND(rowNumber <=@currentPageIndex*@pageSize) END | 
执行结果:

一直想自己实现分页的存储过程,一直没实现,今天没偷懒,言归正传,简略讲下分页的原理:分页有几个参数,当前页序号(即第几页,必须),页大小(每页显示数量,必须),总页数(可选),总记录数(可选),前台查询数据时需要向后台至少发送两个必选参数。参数有了,SQL Server也就不愁分页啦!利用Row_Number的主要原因是要对表进行编号,以确定表中记录是第X页中第X条数据,执行完Row_Number函数的表如下:

看到rowNumber列相信大家都有思路了,只要加上where条件 前一页面*每页大小< rowNumber and。rowNumber <= 当前页面*每页大小 即可,原理就是这些,可以基于这个思路继续拓展,比如传入表名实现通用表或者视图的分页等等。
今天关于SQL分页就介绍到这里,欢迎大家批评指正。
            评论(0)
        
        
        