最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-09 07:01:30
文档

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

MSSQL分页存储过程完整示例(支持多表分页存储):本文实例讲述了MSSQL分页存储过程。分享给大家供大家参考,具体如下: USE [DB_Common] GO /****** 对象: StoredProcedure [dbo].[Com_Pagination] 脚本日期: 03/09/2012 23:46:20 ******/ SET ANSI_NULLS ON GO
推荐度:
导读MSSQL分页存储过程完整示例(支持多表分页存储):本文实例讲述了MSSQL分页存储过程。分享给大家供大家参考,具体如下: USE [DB_Common] GO /****** 对象: StoredProcedure [dbo].[Com_Pagination] 脚本日期: 03/09/2012 23:46:20 ******/ SET ANSI_NULLS ON GO


本文实例讲述了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 实现验证字符串是否包含有大小写字母的功能
  • 文档

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

    MSSQL分页存储过程完整示例(支持多表分页存储):本文实例讲述了MSSQL分页存储过程。分享给大家供大家参考,具体如下: USE [DB_Common] GO /****** 对象: StoredProcedure [dbo].[Com_Pagination] 脚本日期: 03/09/2012 23:46:20 ******/ SET ANSI_NULLS ON GO
    推荐度:
    标签: 实例 分页 mssql
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top