通用游标分页存储过程PageSplit

ALTER procedure [dbo].[PageSplit] 
@sql varchar(max),--要执行的sql语句
@page int=1, --要显示的页码
@pageSize int,--每页的大小
@pageCount int=0 out,--总页数
@recordCount int=0 out--总记录数
as
set nocount on
declare @p1 INT

exec sp_cursoropen @p1 output,@sql,@scrollopt=1,@ccopt=1,@rowcount=@pagecount output
set @recordCount = @pageCount
select @pagecount=ceiling(1.0*@pagecount/@pagesize)
if @page > @pagecount
    select @page = @pagecount
select @page=(@page-1)*@pagesize+1

exec sp_cursorfetch @p1,16,@page,@pagesize 
exec sp_cursorclose @p1

名称栏目:通用游标分页存储过程PageSplit
分享URL:http://scyanting.com/article/ihhisg.html