MSSQL分页存储过程完整示例(支持多表分页存储)

作者:Quber 时间:2024-01-15 10:19:21 

本文实例讲述了MSSQL分页存储过程。分享给大家供大家参考,具体如下:


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,分页,存储过程
0
投稿

猜你喜欢

  • vue动态菜单、动态路由加载以及刷新踩坑实战

    2024-05-05 09:25:27
  • php !function_exists("T7FC56270E7A70FA81A5935B72EACBE29"))代码解密

    2023-11-21 14:36:02
  • vue函数防抖与节流的正确使用方法

    2024-05-29 22:43:01
  • Oracle 处理json数据的方法

    2024-01-16 15:11:15
  • SQL语句之WHERE子句的使用方法

    2007-08-11 12:25:00
  • JS异步宏队列与微队列原理区别详解

    2024-04-22 13:26:36
  • 表单系列·出错字段排行榜

    2008-07-01 12:57:00
  • MyCat环境搭建详细教程

    2024-01-25 01:16:15
  • mysql myisam 优化设置

    2010-03-25 10:18:00
  • PDO::getAvailableDrivers讲解

    2023-06-08 22:24:20
  • 直接生成XML的Google SiteMap的asp代码

    2007-08-17 13:44:00
  • python 接收处理外带的参数方法

    2022-05-01 17:56:26
  • 重新认识ASP之后的我在想"是时候改变了"

    2008-05-08 13:10:00
  • Django 通过JS实现ajax过程详解

    2023-08-17 08:00:46
  • 12种最常用的网页编程语言简介(值得收藏)

    2023-01-29 17:40:48
  • Python 常用 PEP8 编码规范详解

    2022-09-03 06:21:12
  • JavaScript/jQuery实现切换页面效果

    2024-04-22 22:23:17
  • TensorFlow平台下Python实现神经网络

    2023-10-11 22:31:31
  • web标准常见问题集合

    2013-12-25 15:51:19
  • Xml中SelectSingleNode方法中的xpath用法

    2010-01-30 12:46:00
  • asp之家 网络编程 m.aspxhome.com