我们今天主要和大家分享的是SQL Server 2000 分页的存储过程的实际操作流程,以及在实现其实际操作过程中我们应注意的事项的描述。
此文主要讲述的是SQL Server 2000 分页的存储过程,以及对实现SQL Server 2000 分页的存储过程的实际应用代码的描述,以下就是具体方案的描述,希望在你今后的学习中会有所帮助。
- setANSI_NULLSONsetQUOTED_IDENTIFIERONgo
- setANSI_NULLSON
- setQUOTED_IDENTIFIERON
- go
- /*
利用SQL未公开的存储过程实现SQL Server 2000分页方法简单且效率高,已知的问题就是要多返回一个空的记录集解决的方法是在前台调用时,用
- setrecordsetrecordset=recordset.nextrecordset
的方法跳过***个记录集此方法由J9988提供,改成了方便调用的存储过程,邹建2004.05(引用请保留此信息),缺点是返回2张表,***张是空表,第二张才有数据调用示例
- declare@PageCountint
- execsp_PageView
- @sql='select*fromsysobjects',
- @PageCurrent=2,
- @PageCount=@PageCountout
- SELECT@PageCount
- */
- CreatePROC[dbo].[sp_PageView]
- @sqlntext,
要执行的SQL语句
@PageCurrent int=1, 要显示的页码
@PageSize int=10, 每页的大小
@PageCount int OUTPUT 总页数
- AS
- SETNOCOUNTON
- DECLARE@p1int
初始化SQL Server 2000分页游标
- EXECsp_cursoropen
- @cursor=@p1OUTPUT,
- @stmt=@sql,
- @scrollopt=1,
- @ccopt=1,
- @rowcount=@PageCountOUTPUT
计算总页数
- IFISNULL(@PageSize,0)<1
- SET@PageSize=10
- SET@PageCount=(@PageCount+@PageSize-1)/@PageSize
- IFISNULL(@PageCurrent,0)<1ORISNULL(@PageCurrent,0)>@PageCount
- SET@PageCurrent=1
- ELSE
- SET@PageCurrent=(@PageCurrent-1)*@PageSize+1
显示指定页的数据
- EXECsp_cursorfetch@p1,16,@PageCurrent,@PageSize
c关闭SQL Server 2000分页游标
- EXECsp_cursorclose@p1
以上的相关内容就是对SQL Server 2000 分页的存储过程的介绍,望你能有所收获。
【编辑推荐】
- SQL Server 字符串在实际操作中的注意事项
- SQL Server 连接字符串的一些声明
- 链接SQL Server数据库中的字符串经验总结
- 链接SQL Server数据库中的字符串经验总结
- SQL Server数据库中可用格式字符串干什么?
转载请说明出处
知优网 » 如何实现SQL Server 2000 分页的存储过程?
知优网 » 如何实现SQL Server 2000 分页的存储过程?