SqlServer内部的分页功能

SqlServer内部的分页功能,第1张

概述方式一: --利用SQL未公开的存储过程实现分页 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_splitpage]') and OBJECTPROPERTY(id, N'IsProcedure') = 1) drop proc 方式一:
--利用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内部的分页功能所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1180830.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存