MSSQL分頁存儲過程完整示例(支持多表分頁存儲)
更新時間:2016年08月09日 10:43:12 作者:Quber
這篇文章主要介紹了MSSQL分頁存儲過程的實現(xiàn)與使用方法,并支持多表分頁存儲的功能,具有一定參考借鑒價值,需要的朋友可以參考下
本文實例講述了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分頁存儲過程(支持多表分頁存儲)
*
*調(diào)用實例:
EXEC Com_Pagination 100, --總記錄數(shù)
0, --總頁數(shù)
-- 'Person',--查詢的表名
'
Person p
LEFT JOIN TE a
ON a.PID=p.Id
', --查詢的表名(這里為多表)
'a.*', --查詢數(shù)據(jù)列
'p.ID', --排列字段
'p.ID', --分組字段
2, --每頁記錄數(shù)
1, --當前頁數(shù)
0, --是否使用分組,否是
' a.pid=2'--查詢條件
************************************************************/
CREATE PROCEDURE [dbo].[Com_Pagination]
@TotalCount INT OUTPUT, --總記錄數(shù)
@TotalPage INT OUTPUT, --總頁數(shù)
@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, --每頁記錄數(shù)
@CurrentPage INT, --當前頁數(shù)
@Group TINYINT, --是否使用分組,否是
@Condition NVARCHAR(4000) --查詢條件(注意:若這時候為多表查詢,這里也可以跟條件,例如:a.pid=2)
AS
DECLARE @PageCount INT, --總頁數(shù)
@strSql NVARCHAR(4000), --主查詢語句
@strTemp NVARCHAR(2000), --臨時變量
@strCount NVARCHAR(1000), --統(tǒng)計語句
@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
/**調(diào)用實例:
EXEC Com_Pagination 100, --總記錄數(shù)
0, --總頁數(shù)
-- 'Person',--查詢的表名
'
Person p
LEFT JOIN TE a
ON a.PID=p.Id
', --查詢的表名(這里為多表)
'a.*', --查詢數(shù)據(jù)列
'p.ID', --排列字段
'p.ID', --分組字段
2, --每頁記錄數(shù)
1, --當前頁數(shù)
0, --是否使用分組,否是
' a.pid=2'--查詢條件
SELECT a.*
FROM Person p
LEFT JOIN TE a
ON a.PID = p.Id
WHERE a.pid = 2
**/
希望本文所述對大家SQL Server數(shù)據(jù)庫程序設(shè)計有所幫助。
您可能感興趣的文章:
- MS sqlserver 2008數(shù)據(jù)庫轉(zhuǎn)換成2000版本的方法
- MSSql簡單查詢出數(shù)據(jù)表中所有重復數(shù)據(jù)的方法
- PHP封裝的MSSql操作類完整實例
- 拯救你的數(shù)據(jù) 通過日志恢復MSSQL數(shù)據(jù)
- MSSQL產(chǎn)生死鎖的根本原因及解決方法
- SQL(MSSQLSERVER)服務(wù)啟動錯誤代碼3414的解決方法
- PHP連接MSSQL方法匯總
- ASP.NET和MSSQL高性能分頁實例代碼
- 如何處理Python3.4 使用pymssql 亂碼問題
- MS SQL 實現(xiàn)驗證字符串是否包含有大小寫字母的功能
相關(guān)文章
SQL語句實現(xiàn)查詢并自動創(chuàng)建Missing Index
這篇文章主要介紹了SQL語句實現(xiàn)查詢并自動創(chuàng)建Missing Index,本文直接給出SQL實現(xiàn)腳本,需要的朋友可以參考下2015-07-07
Sql?Prompt?10下載與安裝破解圖文教程(最新推薦)
sql?prompt?10是一款擁有智能提示功能的SQL?Server和VS插件,,特別適合開發(fā)者不大熟悉腳本時候使用,這篇文章主要介紹了Sql?Prompt?10下載與安裝破解圖文教程,需要的朋友可以參考下2023-03-03
SQL中的開窗函數(shù)詳解可代替聚合函數(shù)使用
這篇文章主要介紹了SQL中的開窗函數(shù)詳解可代替聚合函數(shù)使用,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03
SQL Server 不刪除信息重新恢復自動編號列的序號的方法
SQL Server 不刪除信息重新恢復自動編號列的序號的方法...2007-11-11

