SqlServer内部的分页功能
来源:互联网 发布:linux 向上翻页 编辑:程序博客网 时间:2024/06/05 06:46
--利用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
--//调用的方式
表
exec up_zbh_DivPageBySql 'select * from 表',10,3
存储过程
exec up_zbh_DivPageBySql 'exec 存储过程',10,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',10,4
存储过程
exec up_zbh_DivPageBySql 'exec 存储过程',10,1
- SqlServer内部的分页功能
- SqlServer内部的分页功能,强啊!!
- SqlServer内部的分页功能,强啊!!
- 利用SqlServer内部存储过程实现快速方便的分页
- 分页,数据库分页功能 SqlServer
- SQLServer分页功能性能优化
- SQLServer的分页SQL
- sqlserver的分页问题
- sqlserver 分页的方法
- SQLServer 的数据分页
- sqlserver的分页
- 最热网友收藏:利用SqlServer内部存储过程实现快速方便的分页(2007年第7周)
- 分页-【存储过程通用的】 【SqlServer分页】
- SQLServer存储过程的分页
- SQLServer存储过程的分页
- sqlserver数据库的分页技术
- mysql和sqlserver的分页
- SQLServer的一种分页写法
- gridview中嵌入label
- CComboBox控件的下拉列表框,用鼠标在该ListBox上滑动的时候显示出当前具有focus的item项的索引
- (c#) Word文档的上传,保存,检索内容文字,转化成HTML 及(在检索 COM 类工厂 错误 80070005 解决方案)
- 未能找到存储过程 master.dbo.sp_addextendedproc 解决办法
- 多重继承和虚继承的内存布局
- SqlServer内部的分页功能
- WIFI驱动设计原理
- JAVA开发环境配置---JDK的安装与配置
- linux 下webloigc出现的问题
- 如何把某个表字段对应的search help引用到自定义的屏幕字段中
- ActiveReports 6.0 - 高效开发UI
- poj 2023 Choose Your Own Adventure 用队列广搜 用栈深搜 用递归深搜 三种方法均测试过
- FusionCharts参数大全
- 免费的sip账号