首页 游戏 软件 资讯 排行榜 专题
首页
数据库
SQL Server 2005通用分页存储过程及多表联接应用

SQL Server 2005通用分页存储过程及多表联接应用

热心网友
58
转载
2026-04-14

SQL Server 2005高效分页存储过程详解与优化

在数据库应用开发中,分页查询是处理海量数据列表与报表展示的核心技术。本文将深入分享一个专为SQL Server 2005设计的通用分页存储过程,该过程巧妙利用ROW_NUMBER()函数实现高效数据分片,在保证优异性能的同时,提供了极高的易用性与灵活性。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

存储过程核心代码解析

以下是经过优化的分页存储过程完整代码。其核心逻辑是通过动态SQL构建,利用ROW_NUMBER()窗口函数为结果集生成连续行号,从而实现精准的数据切片。

复制代码

存储过程代码如下:

if object_ID('[proc_SelectForPager]') is not null
Drop Procedure [proc_SelectForPager]
Go
Create Proc proc_SelectForPager
(
@Sql varchar(max) ,
@Order varchar(4000) ,
@CurrentPage int ,
@PageSize int,
@TotalCount int output
)
As
/*Andy 2012-2-28 */
Declare @Exec_sql nvarchar(max)
Set @Exec_sql='Set @TotalCount=(Select Count(1) From ('+@Sql+') As a)'
Exec sp_executesql @Exec_sql,N'@TotalCount int output',@TotalCount output
Set @Order=isnull(' Order by '+nullif(@Order,''),' Order By getdate()')
if @CurrentPage=1 /*经常会调用第1页,这里做特殊处理,少一层子查询*/
Set @Exec_sql='
;With CTE_Exec As
(
'+@Sql+'
)
Select Top(@pagesize) *,row_number() Over('+@Order+') As r From CTE_Exec Order By r
'
Else
Set @Exec_sql='
;With CTE_Exec As
(
Select *,row_number() Over('+@Order+') As r From ('+@Sql+') As a
)
Select * From CTE_Exec Where r Between (@CurrentPage-1)*@pagesize+1 And @CurrentPage*@pagesize Order By r
'
Exec sp_executesql @Exec_sql,N'@CurrentPage int,@PageSize int',@CurrentPage,@PageSize
Go

存储过程调用方法与实战示例

该分页存储过程设计灵活,能够完美适配单表查询与复杂多表联接等多种数据库应用场景。

1. 单表数据分页查询

对于单表分页需求,直接传入查询语句即可。以下示例演示如何从contacts表中分页获取特定类型的联系人数据:

复制代码

调用示例代码如下:

Exec proc_SelectForPager @Sql = 'Select * from contacts a where a.ContactType=1', -- varchar(max)
@Order = '', -- varchar(4000)
@CurrentPage = 3, -- int
@PageSize = 20, -- int
@TotalCount = 0 -- int

2. 多表联接分页查询

处理涉及多表关联的复杂分页查询同样简便。您只需构建完整的JOIN语句作为参数传入。以下是一个联接staffOUHIST历史表与Staff员工信息表的实战案例:

复制代码

调用示例代码如下:

Exec proc_SelectForPager @Sql =
'Select a.Staff,a.OU,b.FName+b.FName as Name
from staffOUHIST a
inner join Staff b on b.ID=a.Staff and a.ExpiryDate=''30001231''
', -- varchar(max)
@Order = '', -- varchar(4000)
@CurrentPage = 3, -- int
@PageSize = 20, -- int
@TotalCount = 0 -- int

关键注意事项与优化建议:在传入@Sql参数时,查询语句内部应避免使用公共表表达式(CTE)。这是因为存储过程内部已使用CTE进行分页逻辑封装,外部嵌套可能导致语法冲突或执行错误。理解这一设计约束,有助于您构建正确、高效的传入SQL,确保分页存储过程稳定运行。

来源:https://www.jb51.net/article/33538.htm
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

纸嫁衣9手游什么时候出 具体上线日期与预约方法
游戏攻略
纸嫁衣9手游什么时候出 具体上线日期与预约方法

近年来,中式恐怖解谜游戏的热度持续攀升,成为众多玩家关注的焦点。在这一细分领域中,《纸嫁衣》系列凭借其深厚的民俗文化底蕴和极具沉浸感的氛围塑造,已然确立了标杆地位。随着前作口碑的不断积累,玩家对系列新作的期待也日益高涨。目前,官方已正式确认《纸嫁衣9》预计于2026年第三季度,即7月至9月期间发布。

热心网友
05.07
暗区突围受伤急救指南创伤救援玩法与状态处理详解
游戏攻略
暗区突围受伤急救指南创伤救援玩法与状态处理详解

各位战术指挥官请注意,《暗区突围》将于4月30日正式启动限时特别行动——“创伤救援”。本次行动将持续至5月21日,并非简单的模式复刻,而是对团队协作与战术执行能力的一次全新挑战。接下来,我们将深入解析该玩法的核心机制与实战要点,助你提前掌握通关策略。 参与本次行动,你需要提前准备“创伤小组入场券”。

热心网友
05.07
归环灵匿是什么详细解析其背景与作用
游戏攻略
归环灵匿是什么详细解析其背景与作用

在《归环》的开放世界探索中,灵匿系统堪称游戏体验的“灵魂暗线”。它远非一个简单的隐身开关,而是深度融入了探索、叙事与资源循环的核心玩法。透彻理解这一机制,你才能真正掌握《归环》的玩法精髓与设计深度。 启动灵匿的操作十分便捷,按下指定按键,角色即刻进入半透明状态。此时,NPC的常规警戒AI将暂时“休眠

热心网友
05.07
子夜之章专业技能是否过于单调影响游戏体验
游戏攻略
子夜之章专业技能是否过于单调影响游戏体验

《子夜之章》的专业技能体系,正面临关键的转型挑战。自《飞龙军团》版本完成系统性重塑后,这套机制已历经三个资料片的考验。从表面看,它确实变得更加精细与“硬核”,但一个日益凸显的问题是:在“专注”制造模式与“多开角色”策略的双重影响下,普通玩家的经济参与空间正被压缩,整个制造产业链的活力与可持续性也呈现

热心网友
05.07
超级混音带使用体验与音质深度评测报告
游戏攻略
超级混音带使用体验与音质深度评测报告

真正的怀旧,从来不是对某个地点或时代的精确复刻,而是对一种感觉的精准捕捉。那些瞬间的情感闪回,足以唤醒我们沉睡已久的记忆。即便你并非成长于90年代的北加州,即便你的青春与滑板文化毫无交集,这都无关紧要——《超级混音带》深谙此道。澳大利亚开发商Beethoven & Dinosaur用一首首精心挑选的

热心网友
05.07