gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章SQL Server 2005通用分页存储过程及多表联接应用由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

这是不久前写的一个分页存储过程,可应用于SQL Server 2005上面:

复制代码 代码如下

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.单表:

复制代码 代码如下

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.多表联接:

复制代码 代码如下

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.

最后此篇关于SQL Server 2005通用分页存储过程及多表联接应用的文章就讲到这里了,如果你想了解更多关于SQL Server 2005通用分页存储过程及多表联接应用的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com