用oracle中的Row_Number實現分頁

來源:互聯網
上載者:User

標籤:

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)

用oracle中的Row_Number實現分頁

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.