本文实例讲述了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数据库程序设计有所帮助。
本文地址:https://www.stayed.cn/item/16530
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我