SQL Server實現分頁方法介紹
更新時間:2022年03月15日 10:11:37 作者:.NET開發(fā)菜鳥
這篇文章介紹了SQL Server實現分頁的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
一、創(chuàng)建測試表
CREATE TABLE [dbo].[Student]( [id] [int] NOT NULL, [name] [nvarchar](50) NULL, [age] [int] NULL)
二、創(chuàng)建測試數據
declare @i int set @i=1 while(@i<10000) begin insert into Student select @i,left(newid(),7),@i+12 set @i += 1 end
三、測試
1、使用top關鍵字
top關鍵字表示跳過多少條取多少條
declare @pageCount int --每頁條數 declare @pageNo int --頁碼 declare @startIndex int --跳過的條數 set @pageCount=10 set @pageNo=3 set @startIndex=(@pageCount*(@pageNo-1)) select top(@pageCount) * from Student where ID not in ( select top (@startIndex) ID from Student order by id ) order by ID
測試結果:
2、使用row_number()函數
declare @pageCount int --頁數 declare @pageNo int --頁碼 set @pageCount=10 set @pageNo=3 --寫法1:使用between and select t.row,* from ( select ROW_NUMBER() over(order by ID asc) as row,* from Student ) t where t.row between (@pageNo-1)*@pageCount+1 and @pageCount*@pageNo --寫法2:使用 “>”運算符 select top (@pageCount) * from ( select ROW_NUMBER() over(order by ID asc) as row,* from Student ) t where t.row >(@pageNo-1)*@pageCount --寫法3:使用and運算符 select top (@pageCount) * from ( select ROW_NUMBER() over(order by ID asc) as row,* from Student ) t where t.row >(@pageNo-1)*@pageCount and t.row<(@pageNo)*@pageCount+1
四、總結
ROW_NUMBER()只支持sql2005及以上版本,top有更好的可移植性,能同時適用于sql2000及以上版本、access。
這篇文章介紹了SQL Server實現分頁方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
相關文章
SQL SERVER 與ACCESS、EXCEL的數據轉換方法分享
熟悉SQL SERVER 2000的數據庫管理員都知道,其DTS可以進行數據的導入導出,其實,我們也可以使用Transact-SQL語句進行導入導出操作2012-02-02win7系統(tǒng)安裝SQLServer2000的詳細步驟(圖文)
這篇文章主要介紹了win7系統(tǒng)安裝SQLServer2000的詳細步驟,里面有一些需要注意的事項,大家可以參考下2014-07-07IN&EXISTS與NOT IN&NOT EXISTS 的優(yōu)化原則小結
下面只是從理論上提出了一些建議,最好的原則是大家在上面的基礎上,能夠使用執(zhí)行計劃來分析,得出最佳的語句的寫法。2010-06-06