• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MSSQL分页存储过程完整示例(支持多表分页存储)

    本文实例讲述了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数据库程序设计有所帮助。

    您可能感兴趣的文章:
    • MS sqlserver 2008数据库转换成2000版本的方法
    • MSSql简单查询出数据表中所有重复数据的方法
    • PHP封装的MSSql操作类完整实例
    • 拯救你的数据 通过日志恢复MSSQL数据
    • MSSQL产生死锁的根本原因及解决方法
    • SQL(MSSQLSERVER)服务启动错误代码3414的解决方法
    • PHP连接MSSQL方法汇总
    • ASP.NET和MSSQL高性能分页实例代码
    • 如何处理Python3.4 使用pymssql 乱码问题
    • MS SQL 实现验证字符串是否包含有大小写字母的功能
    上一篇:SQL Server 2012 FileTable 新特性详解
    下一篇:MSSql简单查询出数据表中所有重复数据的方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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