MSSQL分页存储过程完整示例(支持多表分页存储) 详解MSSQL分页存储过程
Admin 2021-10-22 群英技术资讯 924 次浏览
这篇文章主要给大家分享关于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
**/
关于mssql分页存储过程就介绍到这,上述实例具有一定的借鉴价值,感兴趣的朋友可以参考,希望能对大家有帮助,想要了解更多mssql分页存储过程的内容,大家可以关注其它的相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
最近处理数据的时候遇到了个问题,需要利用sql删除表格的前1000行数据,尝试过后这里给大家分享下过程,所以下面这篇文章主要给大家介绍了关于sql server删除前1000行数据的相关资料,需要的朋友可以参考下
SQL 克隆数据表 有些情况下,你可能需要原样拷贝某张数据表。但是,CREATE TABLE 却不能满足你的需要,因为复制表必须和原表拥有一样的索引、默认值等等。 如果你在使用 MySQL 关系型数据库管理系统的话,下面几个步骤可以帮你解决这个问题: 使用 SHOW CREATE TABLE 命令来获取一条指定了原表的结构、索引等信息的 CREATE TABLE 语句。 将语句中的表名修改为克隆表的名字,然后执行该语句。这样你就可以得到一张与原表完全相同的克隆表了。 如果你还想要复制表中的数据的话_来自SQL 教程,w3cschool编程狮。
SQL SUM() 函数返回数字列的总和。下文有详解方法和实例,内容详细,逻辑清晰,有需要的朋友可以参考,希望大家阅读完这篇文章后能有所收获,那么下面就一起来了解一下吧。
SQL UNION运算符用于组合两个或更多SELECT语句的结果集,而不返回任何重复的行。UNION中的每个SELECT语句必须具有相同的列数,这些列也必须具有相似的数据类型,每个SELECT语句中的列也必须以相同的顺序排列,每个SELECT语句必须有相同数目的列表达式 但是每个SELECT语句的长度不必相同
这篇文章主要介绍了详解SQL Server表和索引存储结构,有助于大家对SQL存储方式有深入的理解,参考学习下吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008