posts - 21,comments - 64,views - 25003

这几天看到园子里关于T-SQL的文章多了起来,我也抛出一个分页存储过程与大家共享,关于分页存储过程网上的资料非常多,但是我下面要给出的这个的确可以称之为‘非主流’,好不好用大家可以自己测试一下。

 

这个带输出记录总数,速度会稍慢,注意是稍慢,不是很慢,具体能不能满足项目需求可以根据项目可能达到的数据量测试

CREATE PROCEDURE [dbo].[UP_Global_GetPageWithCount]
(
@sql varchar(max),  --SQL语句
@pageindex int,       --需要获取的页码
@pagesize int,        --每一页的记录数量
@pagecount int output --记录总数
)
AS
BEGIN

set nocount on

declare @p1 int   --游标句柄
   
exec sp_cursoropen @p1 output, @sql, @scrollopt=1, @ccopt=1, @rowcount=@pagecount output

set @pageindex = (@pageindex-1)*@pagesize+1        

exec sp_cursorfetch @p1, 16, @pageindex, @pagesize    

exec sp_cursorclose @p1 
 
END

 

 

这个不带输出参数,速度相对较快

CREATE PROCEDURE [dbo].[UP_Global_GetPageNonCount]
(
@sql varchar(max),  --SQL语句
@pageindex int,       --需要获取的页码
@pagesize int         --每一页的记录数量
)
AS
BEGIN

set nocount on  

declare @pagecount int

declare @p1 int   --游标句柄
   
exec sp_cursoropen @p1 output, @sql, @scrollopt=4, @ccopt=1, @rowcount=@pagecount output
   
set @pageindex=(@pageindex-1)*@pagesize+1        

exec sp_cursorfetch @p1, 32, @pageindex, @pagesize    

exec sp_cursorclose @p1
 
END

 

 

这两个存储过程也是N年前在网上淘来的,只是时间过的太久,实在找不到出处了,忘原作者见谅。

这样的通用分页存储过程,大家感觉如何,算不算‘非主流’?呵呵。

 

posted on   王庭安  阅读(3411)  评论(26编辑  收藏  举报
编辑推荐:
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· NetPad:一个.NET开源、跨平台的C#编辑器
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
< 2010年1月 >
27 28 29 30 31 1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31 1 2 3 4 5 6

点击右上角即可分享
微信分享提示