当前位置: 移动技术网 > IT编程>数据库>MSSQL > SQL Server的通用分页存储过程 未使用游标,速度更快!

SQL Server的通用分页存储过程 未使用游标,速度更快!

2017年12月12日  | 移动技术网IT编程  | 我要评论

中卫中学校园网,印度发现14艘中国舰艇,windows7的优点

正常情况下,sql server服务器上会对使用频率大的table建立合适的索引
这样能大幅度的提高数据库本身的数据检索速度,建立索引的方法就不细说了

如果需要返回大量数据,从几百行到几万行,甚至几十万行数据
这时会发现响应速度越来越慢,甚至发生响应超时的错误
为了解决这种大数据量请求的问题,就不得不使用分页模式了

在这方面,jdbc就强悍得多,它可以将指定的行数和sql请求一并发送给sql server,这样只返回分页后的数据,jdbc的原理还不清楚,但在实际使用中,速度还是非常快的

如果没办法使用jdbc,最常用的方法就是存储过程了!

我在写这个分页存储之前,参考了网上的大量相关文章,可以通过关键字:sql server 分页 进行搜索
他们主要都是利用sql中的top方法,并且对所检索的数据结构要求有标识列,如果没有标识列,或者是联合主键,那么就会非常麻烦了。而且对应用里原有的sql检索部分需要修改的地方较多,工作量较大。

因此,我在写这个存储之前就要求一定要对原有的sql脚本最大程度的兼容

经过一个下午的时间,和我一个同事(绝对是高手)的共同努力下,摸索出了以下的思路:

1、确定存储的输入参数:
1)sql脚本,该参数接收完整的、正确的sql检索文本,可将原应用中写好的sql脚本直接传入
2)每页的数据容量,就是一页有多少条数据
3)当前页码
2、确定分页机制:
1)执行传入的sql脚本,并将结果生成临时表
2)修改临时表的结构,增加标识列字段
3)根据标识列字段,计算出指定页码内的记录范围,并返回
4)返回总数据条数,用于客户端进行分页显示

根据以上的思路,编写出以下通用的分页存储过程:

复制代码 代码如下:

[code]
--// ============================
--// sql server通用分页存储过程
--// author : netwild
--// date : 2010/07/22
--// email : netwild@163.com
--// qq : 52100641(网无忌)
--// ============================

set quoted_identifier on
go
set ansi_nulls on
go


create proc execbypage

@sqlquery varchar(2000), --//输入参数:sql检索语句或表名
@pagesize int, --//输入参数:每页显示记录条数
@pageindex int --//输入参数:当前页码

as

set nocount on
set ansi_warnings off

declare @tmptablename varchar(50)
set @tmptablename = '##tb1516_' + replace(cast(newid() as varchar(40)),'-','') --//生成随机临时表名称

declare @subindex int
set @subindex = charindex('from',@sqlquery)
if (@subindex > 0)
begin --//带from的标准检索语句
declare @sqlquery1 varchar(2000)
declare @sqlquery2 varchar(2000)
set @sqlquery1 = substring(@sqlquery,1,@subindex - 1)
set @sqlquery2 = substring(@sqlquery,@subindex,len(@sqlquery))
set @sqlquery = @sqlquery1 + ',identity(numeric,1,1) as id1516 into ' + @tmptablename + ' ' + @sqlquery2
end
else --//不带from的表名
begin
set @sqlquery = 'select *,identity(numeric,1,1) as id1516 into ' + @tmptablename + ' from' + @sqlquery
end
exec(@sqlquery) --//建立并初始化临时表数据

declare @indexstart varchar(20),@indexend varchar(20)
set @indexstart = cast((@pageindex-1)*@pagesize+1 as varchar(20)) --//数据起始行id
set @indexend = cast(@pageindex * @pagesize as varchar(20)) --//数据结束行id

exec('select * from ' + @tmptablename + ' where id1516 between ' + @indexstart + ' and ' + @indexend) --//检索该页数据

exec('select max(id1516) as recordcount from ' + @tmptablename) --//提取总条数

exec('drop table ' + @tmptablename) --//删除临时表


go
set quoted_identifier off
go
set ansi_nulls on
go

[/code]

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网