浅谈基于SQL Server分页存储过程五种方法及性能比较

所属分类: 数据库 / MsSql 阅读数: 1325
收藏 0 赞 0 分享

在SQL Server数据库操作中,我们常常会用到存储过程对实现对查询的数据的分页处理,以方便浏览者的浏览。

创建数据库data_Test :

create database data_Test  
GO  
use data_Test  
GO  
create table tb_TestTable  --创建表  
(  
id int identity(1,1) primary key,  
userName nvarchar(20) not null,  
userPWD nvarchar(20) not null,  
userEmail nvarchar(40) null  
)  
GO 

插入数据:

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进行分页

具体代码如下:

create procedure proc_paged_with_notin --利用select top and select not in  
(  
@pageIndex int, --页索引  
@pageSize int  --每页记录数  
)  
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 not in(select top '+str(@pageSize*@pageIndex)+' id from tb_TestTable order by ID ASC)) order by ID'  
execute(@sql) --因select top后不支技直接接参数,所以写成了字符串@sql  
select datediff(ms,@timediff,GetDate()) as 耗时  
set nocount off;  
end 

2、利用select top 和 select max(列键)

create procedure proc_paged_with_selectMax --利用select top and select max(列)  
(  
@pageIndex int, --页索引  
@pageSize int  --页记录数  
)  
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 耗时  
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 耗时  
set nocount off;  
end 

4、利用Row_number() 此方法为SQL server 2005中新的方法,利用Row_number()给数据行加上索引

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 耗时  
set nocount off;  
end

5、利用临时表及Row_number

create procedure proc_CTE --利用临时表及Row_number  
(  
@pageIndex int, --页索引  
@pageSize int  --页记录数  
)  
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

以上的五种方法中,网上说第三种利用select top和中间变量的方法是效率最高的。关于SQL Server分页存储过程五种方法及性能比较的全部内容就到此结束了,希望对大家有所帮助。

更多精彩内容其他人还在看

简析SQL Server数据库用视图来处理复杂的数据查询关系

本文我们主要介绍了SQL Server数据库用视图来处理复杂的数据查询关系的相关知识,以及视图的优缺点和创建方式以及注意事项的相关知识,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL Server多表查询优化方案集锦

本文我们主要对SQL Server多表查询的优化方案进行了总结,并给出了实际的例子进行性能与效率的对比,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL Server无日志恢复数据库(2种方法)

SQL Server数据库中的日志文件可能会由于一些突发事件或者失误造成丢失的严重后果,大家都知道,SQL Server数据库中日志文件是很重要的,所以要及时的将丢失的日志文件给找回来。下文就为大家介绍一种恢复数据库日志文件的方法。
收藏 0 赞 0 分享

没有SQL Server数据库时如何打开.MDF文件

本文主要介绍了在安装有Visual Studio 2005或以上的版本的前提下,没有安装SQL Server数据库也可以打开.MDF数据库文件的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

通过格式良好的SQL提高效率和准确性

在本文中,作者将分享如何通过格式良好的SQL语句提升生产率,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

升级SQL Server 2014的四个要点要注意

升级一个关键业务SQL Server实例并不容易,它要求有周全的计划。计划不全会增加遇到升级问题的可能性,从而影响或延迟SQL Server 2014的升级。在规划SQLServer 2014升级时,有一些注意事项有助于避免遇到升级问题,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL Server 2005数据库还原错误的经典解决方案

本文主要介绍了一个SQL Server 2005数据库还原过程中的错误的解决方案,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL Server数据库复制失败的原因及解决方法

本文我们主要介绍了SQL Server数据库中由于mssqlserver没有停止造成数据库复制失败的解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

10种Java开发者编写SQL语句时常见错误

这篇文章主要介绍了10种Java开发者编写SQL语句时常见错误,当Java开发人员编写SQL语句时,一切都变得不同了。SQL是一种说明式语言,与面向对象思想和命令式思想无关,需要的朋友可以参考下
收藏 0 赞 0 分享

总结SQL执行进展优化方法

谈到优化就必然要涉及索引,就像要讲锁必然要说事务一样,建议读者先了解一下索引。
收藏 0 赞 0 分享
查看更多