淺談基于SQL Server分頁存儲(chǔ)過程五種方法及性能比較
在SQL Server數(shù)據(jù)庫操作中,我們常常會(huì)用到存儲(chǔ)過程對(duì)實(shí)現(xiàn)對(duì)查詢的數(shù)據(jù)的分頁處理,以方便瀏覽者的瀏覽。
創(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和中間變量
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() declare @strSql nvarchar() 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)上說第三種利用select top和中間變量的方法是效率最高的。關(guān)于SQL Server分頁存儲(chǔ)過程五種方法及性能比較的全部?jī)?nèi)容就到此結(jié)束了,希望對(duì)大家有所幫助。
- mssql 高效的分頁存儲(chǔ)過程分享
- MSSQL MySQL 數(shù)據(jù)庫分頁(存儲(chǔ)過程)
- MsSql 存儲(chǔ)過程分頁代碼 [收集多篇]
- 五種SQL Server分頁存儲(chǔ)過程的方法及性能比較
- SQL Server 分頁查詢通用存儲(chǔ)過程(只做分頁查詢用)
- sqlserver2005利用臨時(shí)表和@@RowCount提高分頁查詢存儲(chǔ)過程性能示例分享
- SQL Server的通用分頁存儲(chǔ)過程 未使用游標(biāo),速度更快!
- sqlserver 存儲(chǔ)過程分頁(按多條件排序)
- MSSQL分頁存儲(chǔ)過程完整示例(支持多表分頁存儲(chǔ))
相關(guān)文章
一個(gè)簡(jiǎn)單的SQL 行列轉(zhuǎn)換語句
在數(shù)據(jù)庫開發(fā)中經(jīng)常會(huì)遇到行列轉(zhuǎn)換的問題,比如下面的問題,部門,員工和員工類型三張表,我們要統(tǒng)計(jì)類似這樣的列表2009-08-08SQL Server 創(chuàng)建約束圖解(唯一 主鍵)
SQLServer中有五種約束,Primary Key約束、Foreign Key約束、Unique約束、Default約束和Check約束,今天使用SQL Server2008來演示下這幾種約束的創(chuàng)建和使用的方法2016-07-07sqlserver 中ntext字段的批量替換(updatetext的用法)
在Sql Server 中,ntext/text/image 字段不允許應(yīng)用replace函數(shù)替換內(nèi)容2009-09-09解決在window下執(zhí)行SQLSERVER定時(shí)備份的問題
這篇文章主要介紹了在window下執(zhí)行SQLSERVER的定時(shí)備份,文末給大家介紹了windows任務(wù)計(jì)劃定時(shí)備份sqlserver數(shù)據(jù)庫的相關(guān)知識(shí),使用windows的任務(wù)計(jì)劃新建一個(gè)sqlserver數(shù)據(jù)庫的定時(shí)備份任務(wù),需要的朋友可以參考下2022-01-01SQL Server 復(fù)制需要有實(shí)際的服務(wù)器名稱才能連接到服務(wù)器
今天在做sql Server 2005的實(shí)驗(yàn)的時(shí)候碰到的問題,問題描述很清楚,懷疑是我以前給計(jì)算機(jī)修改了名稱而導(dǎo)致的.可以用select @@servername和select serverproperty ('servername')對(duì)照一下,兩個(gè)的結(jié)果是否一樣2012-06-06