濮阳杆衣贸易有限公司

主頁 > 知識庫 > SQL Server使用row_number分頁的實現(xiàn)方法

SQL Server使用row_number分頁的實現(xiàn)方法

熱門標簽:互聯(lián)網(wǎng)電話外呼系統(tǒng) 我要地圖標注數(shù)量有限制嗎 安卡拉地圖標注app 電銷需要外呼系統(tǒng)嗎 零成本地圖標注賺錢 電話機器人怎么代理商 家庭農(nóng)場地圖標注名稱怎樣起名 400電話辦理泰安 千呼電話機器人可以試用嗎

本文為大家分享了SQL Server使用row_number分頁的實現(xiàn)方法,供大家參考,具體內(nèi)容如下

1、首先是

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

生成帶序號的集合

2、再查詢該集合的 第 1  到第 5條數(shù)據(jù)

  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)

以上就是本文的全部內(nèi)容,希望對大家學(xué)習(xí)row_number分頁有所幫助。

您可能感興趣的文章:
  • SpringMVC4 + MyBatis3 + SQL Server 2014整合教程(含增刪改查分頁)
  • SQLSERVER分頁查詢關(guān)于使用Top方式和row_number()解析函數(shù)的不同
  • 五種SQL Server分頁存儲過程的方法及性能比較
  • SQL Server 分頁查詢通用存儲過程(只做分頁查詢用)
  • SQL Server 分頁編號的另一種方式【推薦】

標簽:大同 文山 來賓 新鄉(xiāng) 黃山 東營 池州 濱州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《SQL Server使用row_number分頁的實現(xiàn)方法》,本文關(guān)鍵詞  SQL,Server,使用,row,number,分頁,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server使用row_number分頁的實現(xiàn)方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL Server使用row_number分頁的實現(xiàn)方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    清河县| 凤凰县| 邯郸市| 紫云| 隆尧县| 榆树市| 安达市| 酒泉市| 苍梧县| 阳曲县| 南城县| 湟源县| 文成县| 阆中市| 二连浩特市| 澄城县| 札达县| 扎兰屯市| 会东县| 久治县| 新绛县| 城市| 曲沃县| 额济纳旗| 图片| 思茅市| 车险| 仲巴县| 灵宝市| 英山县| 金山区| 阿拉尔市| 苍溪县| 东乌珠穆沁旗| 上林县| 阳原县| 光山县| 洪江市| 定边县| 澎湖县| 饶阳县|