MSSQL分页存储过程完整示例(支持多表分页存储)
2016-08-09 00:00
716 查看
本文实例讲述了MSSQL分页存储过程。分享给大家供大家参考,具体如下:
希望本文所述对大家SQL Server数据库程序设计有所帮助。
MSSQL MySQL 数据库分页(存储过程)
MsSql 存储过程分页代码 [收集多篇]
浅谈基于SQL Server分页存储过程五种方法及性能比较
五种SQL Server分页存储过程的方法及性能比较
SQL Server 分页查询通用存储过程(只做分页查询用)
sqlserver2005利用临时表和@@RowCount提高分页查询存储过程性能示例分享
SQL Server的通用分页存储过程 未使用游标,速度更快!
sqlserver 存储过程分页(按多条件排序)
USE [DB_Common] GO /****** 对象: StoredProcedure [dbo].[Com_Pagination] 脚本日期: 03/09/2012 23:46:20 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO /************************************************************ * *Sql分页存储过程(支持多表分页存储) * *调用实例: EXEC Com_Pagination 100, --总记录数 0, --总页数 -- 'Person',--查询的表名 ' Person p LEFT JOIN TE a ON a.PID=p.Id ', --查询的表名(这里为多表) 'a.*', --查询数据列 'p.ID', --排列字段 'p.ID', --分组字段 2, --每页记录数 1, --当前页数 0, --是否使用分组,否是 ' a.pid=2'--查询条件 ************************************************************/ CREATE PROCEDURE [dbo].[Com_Pagination] @TotalCount INT OUTPUT, --总记录数 @TotalPage INT OUTPUT, --总页数 @Table NVARCHAR(1000), --查询的表名(可多表,例如:Person p LEFT JOIN TE a ON a.PID=p.Id ) @Column NVARCHAR(1000), --查询的字段,可多列或者为* @OrderColumn NVARCHAR(100), --排序字段 @GroupColumn NVARCHAR(150), --分组字段 @PageSize INT, --每页记录数 @CurrentPage INT, --当前页数 @Group TINYINT, --是否使用分组,否是 @Condition NVARCHAR(4000) --查询条件(注意:若这时候为多表查询,这里也可以跟条件,例如:a.pid=2) AS DECLARE @PageCount INT, --总页数 @strSql NVARCHAR(4000), --主查询语句 @strTemp NVARCHAR(2000), --临时变量 @strCount NVARCHAR(1000), --统计语句 @strOrderType NVARCHAR(1000) --排序语句 BEGIN SET @PageCount = @PageSize * (@CurrentPage -1) SET @strOrderType = ' ORDER BY ' + @OrderColumn + ' ' IF @Condition != '' BEGIN IF @CurrentPage = 1 BEGIN IF @GROUP = 1 BEGIN SET @strCount = 'SELECT @TotalCount=COUNT(*) FROM ' + @Table + ' WHERE ' + @Condition + ' GROUP BY ' + @GroupColumn SET @strCount = @strCount + ' SET @TotalCount=@@ROWCOUNT' SET @strSql = 'SELECT TOP ' + STR(@PageSize) + ' ' + @Column + ' FROM ' + @Table + ' WHERE ' + @Condition + ' GROUP BY ' + @GroupColumn + ' ' + @strOrderType END ELSE BEGIN SET @strCount = 'SELECT @TotalCount=COUNT(*) FROM ' + @Table + ' WHERE ' + @Condition SET @strSql = 'SELECT TOP ' + STR(@PageSize) + ' ' + @Column + ' FROM ' + @Table + ' WHERE ' + @Condition + ' ' + @strOrderType END END ELSE BEGIN IF @GROUP = 1 BEGIN SET @strCount = 'SELECT @TotalCount=COUNT(*) FROM ' + @Table + ' WHERE ' + @Condition + ' GROUP BY ' + @GroupColumn SET @strCount = @strCount + ' SET @TotalCount=@@ROWCOUNT' SET @strSql = 'SELECT * FROM (SELECT TOP (2000) ' + @Column + ',ROW_NUMBER() OVER(' + @strOrderType + ') AS NUM FROM ' + @Table + ' WHERE ' + @Condition + ' GROUP BY ' + @GroupColumn + ') AS T WHERE NUM BETWEEN ' + STR(@PageCount + 1) + ' AND ' + STR(@PageCount + @PageSize) END ELSE BEGIN SET @strCount = 'SELECT @TotalCount=COUNT(*) FROM ' + @Table + ' WHERE ' + @Condition SET @strSql = 'SELECT * FROM (SELECT TOP (2000) ' + @Column + ',ROW_NUMBER() OVER(' + @strOrderType + ') AS NUM FROM ' + @Table + ' WHERE ' + @Condition + ') AS T WHERE NUM BETWEEN ' + STR(@PageCount + 1) + ' AND ' + STR(@PageCount + @PageSize) END END END ELSE --没有查询条件 BEGIN IF @CurrentPage = 1 BEGIN IF @GROUP = 1 BEGIN SET @strCount = 'SELECT @TotalCount=COUNT(*) FROM ' + @Table + ' GROUP BY ' + @GroupColumn SET @strCount = @strCount + 'SET @TotalCount=@@ROWCOUNT' SET @strSql = 'SELECT TOP ' + STR(@PageSize) + ' ' + @Column + ' FROM ' + @Table + ' GROUP BY ' + @GroupColumn + ' ' + @strOrderType END ELSE BEGIN SET @strCount = 'SELECT @TotalCount=COUNT(*) FROM ' + @Table SET @strSql = 'SELECT TOP ' + STR(@PageSize) + ' ' + @Column + ' FROM ' + @Table + ' ' + @strOrderType END END ELSE BEGIN IF @GROUP = 1 BEGIN SET @strCount = 'SELECT @TotalCount=COUNT(*) FROM ' + @Table + ' GROUP BY ' + @GroupColumn SET @strCount = @strCount + 'SET @TotalCount=@@ROWCOUNT' SET @strSql = 'SELECT * FROM (SELECT TOP (2000) ' + @Column + ',ROW_NUMBER() OVER(' + @strOrderType + ') AS NUM FROM ' + @Table + ' GROUP BY ' + @GroupColumn + ') AS T WHERE NUM BETWEEN ' + STR(@PageCount + 1) + ' AND ' + STR(@PageCount + @PageSize) END ELSE BEGIN SET @strCount = 'SELECT @TotalCount=COUNT(*) FROM ' + @Table SET @strSql = 'SELECT * FROM (SELECT TOP (2000) ' + @Column + ',ROW_NUMBER() OVER(' + @strOrderType + ') AS NUM FROM ' + @Table + ') AS T WHERE NUM BETWEEN ' + STR(@PageCount + 1) + ' AND ' + STR(@PageCount + @PageSize) END END END EXEC sp_executesql @strCount, N'@TotalCount INT OUTPUT', @TotalCount OUTPUT IF @TotalCount > 2000 BEGIN SET @TotalCount = 2000 END IF @TotalCount%@PageSize = 0 BEGIN SET @TotalPage = @TotalCount / @PageSize END ELSE BEGIN SET @TotalPage = @TotalCount / @PageSize + 1 END SET NOCOUNT ON EXEC (@strSql) END SET NOCOUNT OFF /**调用实例: EXEC Com_Pagination 100, --总记录数 0, --总页数 -- 'Person',--查询的表名 ' Person p LEFT JOIN TE a ON a.PID=p.Id ', --查询的表名(这里为多表) 'a.*', --查询数据列 'p.ID', --排列字段 'p.ID', --分组字段 2, --每页记录数 1, --当前页数 0, --是否使用分组,否是 ' a.pid=2'--查询条件 SELECT a.* FROM Person p LEFT JOIN TE a ON a.PID = p.Id WHERE a.pid = 2 **/
希望本文所述对大家SQL Server数据库程序设计有所帮助。
您可能感兴趣的文章:
mssql 高效的分页存储过程分享MSSQL MySQL 数据库分页(存储过程)
MsSql 存储过程分页代码 [收集多篇]
浅谈基于SQL Server分页存储过程五种方法及性能比较
五种SQL Server分页存储过程的方法及性能比较
SQL Server 分页查询通用存储过程(只做分页查询用)
sqlserver2005利用临时表和@@RowCount提高分页查询存储过程性能示例分享
SQL Server的通用分页存储过程 未使用游标,速度更快!
sqlserver 存储过程分页(按多条件排序)
相关文章推荐
- MySQL存储过程
- more、less 和 most 的区别
- ASP程序与SQL存储过程结合使用详解
- MSSQL转MYSQL的一些记录
- AJAX实现瀑布流触发分页与分页触发瀑布流的方法
- Oracle存储过程之数据库中获取数据实例
- 十万条Access数据表分页的两个解决方法
- MSSQL自身存储过程的一个注入漏洞
- MSSQL 2005 LOG备份webshell的方法
- 关于MSSQL 2005的安装与补丁
- SQL SERVER调用存储过程小结
- SQLServer 2005 列所有存储过程的语句
- mssql server .ldf和.mdf的文件附加数据库的sql语句
- SQL MSSQL 常用代码大全
- SQLServer 2008中的代码安全(一) 存储过程加密与安全上下文
- SQL2005重新生成索引的的存储过程 sp_rebuild
- MSSQL安全设置的具体步骤和方法小结
- SQL Server存储过程的基础说明
- sqlserver存储过程语法详解
- MySQL DDL操作--------存储过程最佳实战