五種SQL Server分頁(yè)存儲(chǔ)過(guò)程的方法及性能比較
在SQL Server數(shù)據(jù)庫(kù)操作中,我們常常會(huì)用到存儲(chǔ)過(guò)程對(duì)實(shí)現(xiàn)對(duì)查詢的數(shù)據(jù)的分頁(yè)處理,以方便瀏覽者的瀏覽。本文我們總結(jié)了五種SQL Server分頁(yè)存儲(chǔ)過(guò)程的方法,并對(duì)其性能進(jìn)行了比較,接下來(lái)就讓我們來(lái)一起了解一下這一過(guò)程。
創(chuàng)建數(shù)據(jù)庫(kù)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)行分頁(yè)
具體代碼如下:
create procedure proc_paged_with_notin --利用select top and select not in ( @pageIndex int, --頁(yè)索引 @pageSize int --每頁(yè)記錄數(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ù),所以寫(xiě)成了字符串@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, --頁(yè)索引 @pageSize int --頁(yè)記錄數(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和中間變量
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, --頁(yè)索引 @pageSize int --頁(yè)記錄數(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
以上的五種方法中,網(wǎng)上說(shuō)第三種利用select top和中間變量的方法是效率最高的。
關(guān)于SQL Server數(shù)據(jù)庫(kù)分頁(yè)的存儲(chǔ)過(guò)程的五種方法及性能比較的知識(shí)就介紹到這里了,希望對(duì)大家的學(xué)習(xí)有所幫助。
相關(guān)文章
SQLServer2019配置端口號(hào)的實(shí)現(xiàn)
這篇文章主要介紹了SQLServer2019配置端口號(hào)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04通過(guò)T_sql語(yǔ)句向其中一次填入一條數(shù)據(jù)或一次填入多條數(shù)據(jù)的方式填充數(shù)據(jù)
使用T_sql語(yǔ)句向其中一次填入一條數(shù)據(jù)或一次填入多條數(shù)據(jù)的方式填入數(shù)據(jù),需要的朋友可以參考下2012-10-10SQL語(yǔ)句計(jì)算兩個(gè)日期之間有多少個(gè)工作日的方法
本文的主要內(nèi)容是用SQL語(yǔ)言計(jì)算兩個(gè)日期間有多少個(gè)工作日,需要的朋友可以參考下2015-08-08返回SQL執(zhí)行時(shí)間的存儲(chǔ)過(guò)程
返回任何SQL執(zhí)行時(shí)間(到毫秒,sql 2000)2009-10-10使用xp_cmdshell注銷(xiāo)Windows登錄用戶(終端服務(wù)器超出最大連接數(shù))
關(guān)于終端服務(wù)器超出最大連接數(shù)的解決方法有很多種,最簡(jiǎn)單的就是下載加強(qiáng)版本客戶端即可,下面的文章主要是介紹了sqlserver中通過(guò)xp_cmdshell用戶2012-12-12sqlserver服務(wù)器驗(yàn)證改為混合驗(yàn)證模式步驟
如果在安裝SQL Server數(shù)據(jù)庫(kù)時(shí),一時(shí)疏忽使用了Windows集成驗(yàn)證方式,事后還是可以更改為混合驗(yàn)證模式的,步驟如下2013-12-12sql server 自定義分割月功能詳解及實(shí)現(xiàn)代碼
這篇文章主要介紹了sql server 自定義分割月功能詳解及實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2016-10-10使用SQL批量替換語(yǔ)句修改、增加、刪除字段內(nèi)容
sql替換語(yǔ)句,用該命令可以整批替換某字段的內(nèi)容,也可以批量在原字段內(nèi)容上加上或去掉字符。本文給大家介紹使用SQL批量替換語(yǔ)句修改、增加、刪除字段內(nèi)容的知識(shí),非常不錯(cuò),感興趣的朋友一起學(xué)習(xí)吧2016-08-08sqlserver利用存儲(chǔ)過(guò)程去除重復(fù)行的sql語(yǔ)句
以前弄過(guò)類(lèi)似,去除相同信息的方法,現(xiàn)在找不到了,不過(guò)今天又花一些時(shí)間給弄出來(lái)了,記錄一下2010-06-06