SQL Server 2005通用分页存储过程及多表联接应用
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,确保分页存储过程稳定运行。
热门专题
热门推荐
近年来,中式恐怖解谜游戏的热度持续攀升,成为众多玩家关注的焦点。在这一细分领域中,《纸嫁衣》系列凭借其深厚的民俗文化底蕴和极具沉浸感的氛围塑造,已然确立了标杆地位。随着前作口碑的不断积累,玩家对系列新作的期待也日益高涨。目前,官方已正式确认《纸嫁衣9》预计于2026年第三季度,即7月至9月期间发布。
各位战术指挥官请注意,《暗区突围》将于4月30日正式启动限时特别行动——“创伤救援”。本次行动将持续至5月21日,并非简单的模式复刻,而是对团队协作与战术执行能力的一次全新挑战。接下来,我们将深入解析该玩法的核心机制与实战要点,助你提前掌握通关策略。 参与本次行动,你需要提前准备“创伤小组入场券”。
在《归环》的开放世界探索中,灵匿系统堪称游戏体验的“灵魂暗线”。它远非一个简单的隐身开关,而是深度融入了探索、叙事与资源循环的核心玩法。透彻理解这一机制,你才能真正掌握《归环》的玩法精髓与设计深度。 启动灵匿的操作十分便捷,按下指定按键,角色即刻进入半透明状态。此时,NPC的常规警戒AI将暂时“休眠
《子夜之章》的专业技能体系,正面临关键的转型挑战。自《飞龙军团》版本完成系统性重塑后,这套机制已历经三个资料片的考验。从表面看,它确实变得更加精细与“硬核”,但一个日益凸显的问题是:在“专注”制造模式与“多开角色”策略的双重影响下,普通玩家的经济参与空间正被压缩,整个制造产业链的活力与可持续性也呈现
真正的怀旧,从来不是对某个地点或时代的精确复刻,而是对一种感觉的精准捕捉。那些瞬间的情感闪回,足以唤醒我们沉睡已久的记忆。即便你并非成长于90年代的北加州,即便你的青春与滑板文化毫无交集,这都无关紧要——《超级混音带》深谙此道。澳大利亚开发商Beethoven & Dinosaur用一首首精心挑选的





