--利用sql未公开的存储过程实现分页 if exists (select * from dbo.sysobjects where ID = object_ID(N'[dbo].[p_splitpage]') and OBJECTPROPERTY(ID,N'IsProcedure') = 1) drop procedure [dbo].[p_splitpage] GO create procedure p_splitpage @sql nvarchar(4000),--要执行的SQL语句 @currentpage int=2,--要显示的页码 @pagesize int=10,--每页的大小 @recordcount int=0 out,--记录数 @pagecount int=0 out --总页数 as set nocount on declare @p1 int exec sp_cursoropen @p1 output,@sql,@scrollopt=1,@ccopt=1,@rowcount=@pagecount output select @recordcount=@pagecount,@pagecount=ceiling(1.0*@pagecount/@pagesize),@currentpage=(@currentpage-1)*@pagesize+1 select @recordcount recordcount,@pagecount pagecount,@currentpage currentpage exec sp_cursorfetch @p1,16,@currentpage,@pagesize exec sp_cursorclose @p1 go方式二:
CREATE PROC spGetPages2 @iRowCount INT,@iPageNo INTASSELECT * FROM (SELECT ROW_NUMBER() OVER(ORDER BY ProductID ASC) RowNum,* FROM Production.Product ) OrderDataWHERE RowNum BETWEEN @iRowCount*(@iPageNo-1)+1 AND @iRowCount*@iPageNoORDER BY ProductID ASCGOEXEC spGetPages2 10,20---------------------------------- 方式三: 1)只需要提供SQL语句和每页的记录数,页数就可以了 2)速度超快哟,100W记录1~3秒就分出来了 3)对于存储过程特别好用
--//调用的方式
表
exec up_zbh_divPageBysql 'select * from 表',10,3
存储过程
exec up_zbh_divPageBysql 'exec 存储过程',1
--//我把它封装成一个存储过程,调用的时候方便的很哈!!
create procedure up_zbh_divPageBysql
@strsql varchar(8000),
@nPageSize int,
@nPageCount int
as
SET NOCOUNT ON
DECLARE @P1 INT,
@nRowCount INT
--//注意:@scrollopt = 1 会取得Select的时候的总行数
EXEC sp_cursoropen @P1 OUTPUT,@strsql,@scrollopt = 2,@ccopt = 335873,@rowcount = @nRowCount OUTPUT
IF (@P1 != 0)
BEGIN
--SELECT @nRowCount AS nRecordCount,ceiling(1.0 * @nRowCount / @nPageSize) AS nPageCount,@nPageCount AS nPage
SET @nPageCount = (@nPageCount - 1) * @nPageSize + 1
EXEC sp_cursorfetch @P1,32,@nPageCount,@nPageSize
EXEC sp_cursorclose @P1
END
GO
--//调用的方式表exec up_zbh_divPageBysql 'select * from ptype',4存储过程exec up_zbh_divPageBysql 'exec 存储过程',1
总结以上是内存溢出为你收集整理的SqlServer内部的分页功能全部内容,希望文章能够帮你解决SqlServer内部的分页功能所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)