≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

五种SQL Server分页存储过程的方法及性能比较

人气:337 时间:2020-05-29

这篇文章主要为大家详细介绍了五种SQL Server分页存储过程的方法及性能比较,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

在SQL Server数据库操作中,我们常常会用到存储过程对实现对查询的数据的分页处理,以方便浏览者的浏览。本文我们总结了五种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(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 

以上的五种方法中,网上说第三种利用select top和中间变量的方法是效率最高的。

关于SQL Server数据库分页的存储过程的五种方法及性能比较的知识就介绍到这里了,希望对大家的学习有所帮助。

本文来自:http://www.q1010.com/179/8787-0.html

注:关于五种SQL Server分页存储过程的方法及性能比较的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • 数据库触发器DB2和SqlServer区别解析
  • 解决在Azure上部署Sqlserver网络访问不了示例
  • 在sqlserver中如何使用CTE解决复杂查询问题
  • SqlServer应用之sys.dm_os_waiting_tasks 引发的疑问(下)
  • SQLServer存储过程中事务的使用方法
  • 使用SqlServer CTE递归查询处理树、图和层次结构
  • SqlServer如何通过SQL语句获取处理器(CPU)、内存(Memory)、磁盘(Disk)以及操作系统相关信息
  • SQLServer中merge函数用法分析
  • SqlServer应用之sys.dm_os_waiting_tasks 引发的疑问(中)
  • SQLServer中Partition By及row_number 函数使用分析
上一篇:SQL Server开窗函数有浅入深分析(一)
下一篇:解决SQL Server无法启动的简单示例
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。