zoukankan      html  css  js  c++  java
  • Row_Number实现分页

    1:首先是

        select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1

       生成带序号的集合

    2:再查询该集合的 第 1  到第 5条数据

        select * from
        (select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1) as temp
        where rowNumber between 1 and 5

    完整的Sql语句

    declare @pagesize int; declare @pageindex int; set @pagesize = 3

    set @pageindex = 1; --第一页

    select * from (select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1) as temp where rowNumber between (((@pageindex-1)*@pagesize)+1) and (@pageindex*@pagesize)

    set @pageindex = 2; --第二页

    select * from (select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1) as temp where rowNumber between (((@pageindex-1)*@pagesize)+1) and (@pageindex*@pagesize)

    set @pageindex = 3; --第三页

    select * from (select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1) as temp where rowNumber between (((@pageindex-1)*@pagesize)+1) and (@pageindex*@pagesize)

    set @pageindex = 4;--第四页

    select * from (select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1) as temp where rowNumber between (((@pageindex-1)*@pagesize)+1) and (@pageindex*@pagesize)

    下面我们来写个存储过程分页

    ------------------------------

    Alter Procedure PagePager   

    @TableName varchar(80),   

    @File varchar(1000),---   

    @Where varchar(500),---带and连接   

    @OrderFile varchar(100), -- 排序字段   

    @OrderType varchar(10),--asc:顺序,desc:倒序   

    @PageSize varchar(10), --   

    @PageIndex varchar(10) --  

    as      

    if(ISNULL(@OrderFile, '') = '')   

    begin     

    set @OrderFile = 'ID';   

    end   

    if(ISNULL(@OrderType,'') = '')   

    begin     

    set @OrderType = 'asc'   

    end   

    if(ISNULL(@File,'') = '')   

    begin     

    set @File = '*'   

    end      

    declare @select varchar(8000)   

    set @select = '    select ' + @File + ' from     (       select *,ROW_NUMBER() over(order by ' + @OrderFile + '  '+ @OrderType + ') as ''rowNumber''    from ' + @TableName + '    where 1=1 ' + @Where + '     )  temp where  rowNumber between (((' + @PageIndex + ' - 1) * ' + @PageSize + ')+1) and (' + @PageIndex + '*'+ @PageSize+')'   

    exec(@select)

  • 相关阅读:
    boost::asio在VS2008下的编译错误
    Java集合框架——接口
    ACM POJ 3981 字符串替换(简单题)
    ACM HDU 1042 N!(高精度计算阶乘)
    OneTwoThree (Uva)
    ACM POJ 3979 分数加减法(水题)
    ACM HDU 4004 The Frog's Games(2011ACM大连赛区第四题)
    Hexadecimal View (2011ACM亚洲大连赛区现场赛D题)
    ACM HDU 4002 Find the maximum(2011年大连赛区网络赛第二题)
    ACM HDU 4001 To Miss Our Children Time (2011ACM大连赛区网络赛)
  • 原文地址:https://www.cnblogs.com/ajun/p/2814780.html
Copyright © 2011-2022 走看看