主頁(yè) > 知識(shí)庫(kù) > MSSQL分頁(yè)存儲(chǔ)過(guò)程完整示例(支持多表分頁(yè)存儲(chǔ))

MSSQL分頁(yè)存儲(chǔ)過(guò)程完整示例(支持多表分頁(yè)存儲(chǔ))

熱門標(biāo)簽:400電話辦理泰安 電銷需要外呼系統(tǒng)嗎 千呼電話機(jī)器人可以試用嗎 我要地圖標(biāo)注數(shù)量有限制嗎 互聯(lián)網(wǎng)電話外呼系統(tǒng) 安卡拉地圖標(biāo)注app 電話機(jī)器人怎么代理商 零成本地圖標(biāo)注賺錢 家庭農(nóng)場(chǎng)地圖標(biāo)注名稱怎樣起名

本文實(shí)例講述了MSSQL分頁(yè)存儲(chǔ)過(guò)程。分享給大家供大家參考,具體如下:

USE [DB_Common]
GO
/****** 對(duì)象: StoredProcedure [dbo].[Com_Pagination]  腳本日期: 03/09/2012 23:46:20 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
/************************************************************
 *
 *Sql分頁(yè)存儲(chǔ)過(guò)程(支持多表分頁(yè)存儲(chǔ))
 *
 *調(diào)用實(shí)例:
 EXEC Com_Pagination 100, --總記錄數(shù)
   0, --總頁(yè)數(shù)
    -- 'Person',--查詢的表名
   '
           Person p
           LEFT JOIN TE a
           ON a.PID=p.Id 
          ', --查詢的表名(這里為多表)
   'a.*', --查詢數(shù)據(jù)列
   'p.ID', --排列字段
   'p.ID', --分組字段
   2, --每頁(yè)記錄數(shù)
   1, --當(dāng)前頁(yè)數(shù)
   0, --是否使用分組,否是
   ' a.pid=2'--查詢條件
 ************************************************************/
CREATE PROCEDURE [dbo].[Com_Pagination]
@TotalCount INT OUTPUT, --總記錄數(shù)
@TotalPage INT OUTPUT, --總頁(yè)數(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, --每頁(yè)記錄數(shù)
@CurrentPage INT, --當(dāng)前頁(yè)數(shù)
@Group TINYINT, --是否使用分組,否是
@Condition NVARCHAR(4000) --查詢條件(注意:若這時(shí)候?yàn)槎啾聿樵?,這里也可以跟條件,例如:a.pid=2)
AS
DECLARE @PageCount   INT, --總頁(yè)數(shù)
    @strSql    NVARCHAR(4000), --主查詢語(yǔ)句
    @strTemp    NVARCHAR(2000), --臨時(shí)變量
    @strCount   NVARCHAR(1000), --統(tǒng)計(jì)語(yǔ)句
    @strOrderType NVARCHAR(1000) --排序語(yǔ)句
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
  --沒(méi)有查詢條件
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)用實(shí)例:
EXEC Com_Pagination 100, --總記錄數(shù)
   0, --總頁(yè)數(shù)
    -- 'Person',--查詢的表名
   '
           Person p
           LEFT JOIN TE a
           ON a.PID=p.Id 
          ', --查詢的表名(這里為多表)
   'a.*', --查詢數(shù)據(jù)列
   'p.ID', --排列字段
   'p.ID', --分組字段
   2, --每頁(yè)記錄數(shù)
   1, --當(dāng)前頁(yè)數(shù)
   0, --是否使用分組,否是
   ' a.pid=2'--查詢條件
SELECT a.* 
FROM  Person p
    LEFT JOIN TE a
      ON a.PID = p.Id
WHERE a.pid = 2
**/

希望本文所述對(duì)大家SQL Server數(shù)據(jù)庫(kù)程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • MS sqlserver 2008數(shù)據(jù)庫(kù)轉(zhuǎn)換成2000版本的方法
  • MSSql簡(jiǎn)單查詢出數(shù)據(jù)表中所有重復(fù)數(shù)據(jù)的方法
  • PHP封裝的MSSql操作類完整實(shí)例
  • 拯救你的數(shù)據(jù) 通過(guò)日志恢復(fù)MSSQL數(shù)據(jù)
  • MSSQL產(chǎn)生死鎖的根本原因及解決方法
  • SQL(MSSQLSERVER)服務(wù)啟動(dòng)錯(cuò)誤代碼3414的解決方法
  • PHP連接MSSQL方法匯總
  • ASP.NET和MSSQL高性能分頁(yè)實(shí)例代碼
  • 如何處理Python3.4 使用pymssql 亂碼問(wèn)題
  • MS SQL 實(shí)現(xiàn)驗(yàn)證字符串是否包含有大小寫(xiě)字母的功能

標(biāo)簽:新鄉(xiāng) 濱州 大同 來(lái)賓 東營(yíng) 文山 池州 黃山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MSSQL分頁(yè)存儲(chǔ)過(guò)程完整示例(支持多表分頁(yè)存儲(chǔ))》,本文關(guān)鍵詞  MSSQL,分頁(yè),存儲(chǔ),過(guò)程,完整,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MSSQL分頁(yè)存儲(chǔ)過(guò)程完整示例(支持多表分頁(yè)存儲(chǔ))》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MSSQL分頁(yè)存儲(chǔ)過(guò)程完整示例(支持多表分頁(yè)存儲(chǔ))的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章