------創(chuàng)建數(shù)據(jù)庫data_Test ----- create database data_Test GO use data_Test GO create table tb_TestTable --創(chuàng)建表 ( id int identity(1,1) primary key, userName nvarchar(20) not null, userPWD nvarchar(20) not null, userEmail nvarchar(40) null ) GO ------插入數(shù)據(jù)------ set identity_insert tb_TestTable on declare @count int set @count=1 while @count<=2000000 begin insert into tb_TestTable(id,userName,userPWD,userEmail) values(@count,'admin','admin888','lli0077@yahoo.com.cn') set @count=@count+1 end set identity_insert tb_TestTable off ---1、利用select top 和select not in進(jìn)行分頁,具體代碼如下 create procedure proc_paged_with_notin --利用select top and select not in ( @pageIndex int, --頁索引 @pageSize int --每頁記錄數(shù) ) as begin set nocount on; declare @timediff datetime --耗時(shí) declare @sql nvarchar(500) select @timediff=Getdate() set @sql='select top '+str(@pageSize)+' * from tb_TestTable where(ID not in(select top '+str(@pageSize*@pageIndex)+' id from tb_TestTable order by ID ASC)) order by ID' execute(@sql) --因select top后不支技直接接參數(shù),所以寫成了字符串@sql select datediff(ms,@timediff,GetDate()) as 耗時(shí) set nocount off; end ---2、利用select top 和 select max(列鍵)--- create procedure proc_paged_with_selectMax --利用select top and select max(列) ( @pageIndex int, --頁索引 @pageSize int --頁記錄數(shù) ) as begin set nocount on; declare @timediff datetime declare @sql nvarchar(500) select @timediff=Getdate() set @sql='select top '+str(@pageSize)+' * From tb_TestTable where(ID>(select max(id) From (select top '+str(@pageSize*@pageIndex)+' id From tb_TestTable order by ID) as TempTable)) order by ID' execute(@sql) select datediff(ms,@timediff,GetDate()) as 耗時(shí) set nocount off; end ---3、利用select top和中間變量--此方法因網(wǎng)上有人說效果最佳--- create procedure proc_paged_with_Midvar --利用ID>最大ID值和中間變量 ( @pageIndex int, @pageSize int ) as declare @count int declare @ID int declare @timediff datetime declare @sql nvarchar(500) begin set nocount on; select @count=0,@ID=0,@timediff=getdate() select @count=@count+1,@ID=case when @count<=@pageSize*@pageIndex then ID else @ID end from tb_testTable order by id set @sql='select top '+str(@pageSize)+' * from tb_testTable where ID>'+str(@ID) execute(@sql) select datediff(ms,@timediff,getdate()) as 耗時(shí) set nocount off; end ---4、利用Row_number() 此方法為SQL server 2005中新的方法,利用Row_number()給數(shù)據(jù)行加上索引 create procedure proc_paged_with_Rownumber --利用SQL 2005中的Row_number() ( @pageIndex int, @pageSize int ) as declare @timediff datetime begin set nocount on; select @timediff=getdate() select * from (select *,Row_number() over(order by ID asc) as IDRank from tb_testTable) as IDWithRowNumber where IDRank>@pageSize*@pageIndex and IDRank<@pageSize*(@pageIndex+1) select datediff(ms,@timediff,getdate()) as 耗時(shí) set nocount off; end ---5、利用臨時(shí)表及Row_number create procedure proc_CTE --利用臨時(shí)表及Row_number ( @pageIndex int, --頁索引 @pageSize int --頁記錄數(shù) ) as set nocount on; declare @ctestr nvarchar(400) declare @strSql nvarchar(400) declare @datediff datetime begin select @datediff=GetDate() set @ctestr='with Table_CTE as (select ceiling((Row_number() over(order by ID ASC))/'+str(@pageSize)+') as page_num,* from tb_TestTable)'; set @strSql=@ctestr+' select * From Table_CTE where page_num='+str(@pageIndex) end begin execute sp_executesql @strSql select datediff(ms,@datediff,GetDate()) set nocount off; end
存儲(chǔ)過程的5種分頁寫法,下面的代碼是從忘了什么時(shí)候從別人那Ctrl+C來的,所以僅僅作為收藏,希望作者看到不要噴我.
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
