濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > SqlServer 2000、2005分頁(yè)存儲(chǔ)過(guò)程整理第1/3頁(yè)

SqlServer 2000、2005分頁(yè)存儲(chǔ)過(guò)程整理第1/3頁(yè)

熱門(mén)標(biāo)簽:寧波人工外呼系統(tǒng)有效果嗎 怎樣把地圖標(biāo)注導(dǎo)入公司地址 廣州人工電銷(xiāo)機(jī)器人費(fèi)用 真人語(yǔ)音電銷(xiāo)機(jī)器人 洛陽(yáng)外呼系統(tǒng)平臺(tái) 如何在地圖標(biāo)注自己店鋪 電銷(xiāo)機(jī)器人被曝光 地圖標(biāo)注一個(gè)圓圈怎么用 400外呼系統(tǒng)合法

sql server 2005的分頁(yè)存儲(chǔ)過(guò)程分3個(gè)版本,一個(gè)是沒(méi)有優(yōu)化過(guò)的,一個(gè)是優(yōu)化過(guò)的,最后一個(gè)支持join的,sql server 2000的分頁(yè)存儲(chǔ)過(guò)程,也可以運(yùn)行在sql server 2005上,但是性能沒(méi)有sql server 2005的版本好。

在最后 我還附帶了一個(gè)二分法的分頁(yè)存儲(chǔ)過(guò)程,也很好用的說(shuō)哈~~

1.SqlServer 2005:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

CREATE proc [dbo].[up_Page2005]
 @TableName varchar(50),    --表名
 @Fields varchar(5000) = '*',  --字段名(全部字段為*)
 @OrderField varchar(5000),    --排序字段(必須!支持多字段)
 @sqlWhere varchar(5000) = Null,--條件語(yǔ)句(不用加where)
 @pageSize int,          --每頁(yè)多少條記錄
 @pageIndex int = 1 ,      --指定當(dāng)前為第幾頁(yè)
 @TotalPage int output      --返回總頁(yè)數(shù)
as
begin

  Begin Tran --開(kāi)始事務(wù)

  Declare @sql nvarchar(4000);
  Declare @totalRecord int;

  --計(jì)算總記錄數(shù)

  if (@SqlWhere='' or @sqlWhere=NULL)
    set @sql = 'select @totalRecord = count(*) from ' + @TableName
  else
    set @sql = 'select @totalRecord = count(*) from ' + @TableName + ' with(nolock) where ' + @sqlWhere

  EXEC sp_executesql @sql,N'@totalRecord int OUTPUT',@totalRecord OUTPUT--計(jì)算總記錄數(shù)

  --計(jì)算總頁(yè)數(shù)
  select @TotalPage=CEILING((@totalRecord+0.0)/@PageSize)

  if (@SqlWhere='' or @sqlWhere=NULL)
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName
  else
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName + ' with(nolock) where ' + @SqlWhere

  --處理頁(yè)數(shù)超出范圍情況
  if @PageIndex=0
    Set @pageIndex = 1

  if @pageIndex>@TotalPage
    Set @pageIndex = @TotalPage

   --處理開(kāi)始點(diǎn)和結(jié)束點(diǎn)
  Declare @StartRecord int
  Declare @EndRecord int

  set @StartRecord = (@pageIndex-1)*@PageSize + 1
  set @EndRecord = @StartRecord + @pageSize - 1

  --繼續(xù)合成sql語(yǔ)句
  set @Sql = @Sql + ') as t where rowId between ' + Convert(varchar(50),@StartRecord) + ' and ' + Convert(varchar(50),@EndRecord)
   print @sql
  Exec(@Sql)
  ---------------------------------------------------
  If @@Error > 0
   Begin
    RollBack Tran
    Return -1
   End
   Else
   Begin
    Commit Tran
    Return @totalRecord ---返回記錄總數(shù)
   End
end

2.Sql Server 2005:

/****** 對(duì)象: StoredProcedure [dbo].[up_Page2005V2]  腳本日期: 05/21/2008 11:27:15 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:    Author,,Name>
-- Create date: Create Date,,>
-- Description:  Description,,>
-- =============================================
CREATE PROCEDURE [dbo].[up_Page2005V2]
  @TableName varchar(50),    --表名
 @Fields varchar(5000) = '*',  --字段名(全部字段為*)
 @OrderField varchar(5000),    --排序字段(必須!支持多字段)
 @sqlWhere varchar(5000) = Null,--條件語(yǔ)句(不用加where)
 @pageSize int,          --每頁(yè)多少條記錄
 @pageIndex int = 1 ,      --指定當(dāng)前為第幾頁(yè)
 @totalRecord int = 0,
 @TotalPage int output      --返回總頁(yè)數(shù)
AS
BEGIN

   Begin Tran --開(kāi)始事務(wù)

  Declare @sql nvarchar(4000);

  if @totalRecord=0 begin
    --計(jì)算總記錄數(shù)

    if (@SqlWhere='' or @sqlWhere=NULL)
      set @sql = 'select @totalRecord = count(*) from ' + @TableName
    else
      set @sql = 'select @totalRecord = count(*) from ' + @TableName + ' with(nolock) where ' + @sqlWhere

    EXEC sp_executesql @sql,N'@totalRecord int OUTPUT',@totalRecord OUTPUT--計(jì)算總記錄數(shù)
  end

  --計(jì)算總頁(yè)數(shù)
  select @TotalPage=CEILING((@totalRecord+0.0)/@PageSize)

  if (@SqlWhere='' or @sqlWhere=NULL)
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName
  else
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName + ' with(nolock) where ' + @SqlWhere

  --處理頁(yè)數(shù)超出范圍情況
  if @PageIndex=0
    Set @pageIndex = 1

  if @pageIndex>@TotalPage
    Set @pageIndex = @TotalPage

   --處理開(kāi)始點(diǎn)和結(jié)束點(diǎn)
  Declare @StartRecord int
  Declare @EndRecord int

  set @StartRecord = (@pageIndex-1)*@PageSize + 1
  set @EndRecord = @StartRecord + @pageSize - 1

  --繼續(xù)合成sql語(yǔ)句
  set @Sql = @Sql + ') as t where rowId between ' + Convert(varchar(50),@StartRecord) + ' and ' + Convert(varchar(50),@EndRecord)
   print @sql
  Exec(@Sql)
  ---------------------------------------------------
  If @@Error > 0
   Begin
    RollBack Tran
    Return -1
   End
   Else
   Begin
    Commit Tran
    Return @totalRecord ---返回記錄總數(shù)
   End
END

GO

3.Sql Server 2005:

/****** 對(duì)象: StoredProcedure [dbo].[up_Page2005V2_Join]  腳本日期: 05/21/2008 11:27:30 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE [dbo].[up_Page2005V2_Join]
  @TableName varchar(150),    --表名
 @Fields varchar(5000) = '*',  --字段名(全部字段為*)
 @OrderField varchar(5000),    --排序字段(必須!支持多字段)
 @sqlWhere varchar(5000) = Null,--條件語(yǔ)句(不用加where)
 @pageSize int,          --每頁(yè)多少條記錄
 @pageIndex int = 1 ,      --指定當(dāng)前為第幾頁(yè)
 @totalRecord int = 0,
 @TotalPage int output      --返回總頁(yè)數(shù)
AS
BEGIN

   Begin Tran --開(kāi)始事務(wù)

  Declare @sql nvarchar(4000);

  if @totalRecord=0 begin
    --計(jì)算總記錄數(shù)

    if (@SqlWhere='' or @sqlWhere=NULL)
      set @sql = 'select @totalRecord = count(*) from ' + @TableName
    else
      set @sql = 'select @totalRecord = count(*) from ' + @TableName + ' where ' + @sqlWhere

    EXEC sp_executesql @sql,N'@totalRecord int OUTPUT',@totalRecord OUTPUT--計(jì)算總記錄數(shù)
  end

  --計(jì)算總頁(yè)數(shù)
  select @TotalPage=CEILING((@totalRecord+0.0)/@PageSize)

  if (@SqlWhere='' or @sqlWhere=NULL)
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName
  else
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName + ' where ' + @SqlWhere

  --處理頁(yè)數(shù)超出范圍情況
  if @PageIndex=0
    Set @pageIndex = 1

  if @pageIndex>@TotalPage
    Set @pageIndex = @TotalPage

   --處理開(kāi)始點(diǎn)和結(jié)束點(diǎn)
  Declare @StartRecord int
  Declare @EndRecord int

  set @StartRecord = (@pageIndex-1)*@PageSize + 1
  set @EndRecord = @StartRecord + @pageSize - 1

  --繼續(xù)合成sql語(yǔ)句
  set @Sql = @Sql + ') as t where rowId between ' + Convert(varchar(50),@StartRecord) + ' and ' + Convert(varchar(50),@EndRecord)
   print @sql

  Exec(@Sql)
  ---------------------------------------------------
  If @@Error > 0
   Begin
    RollBack Tran
    Return -1
   End
   Else
   Begin
    Commit Tran
    Return @totalRecord ---返回記錄總數(shù)
   End
END

4.Sql Server 2000:

USE [game]
GO
/****** 對(duì)象: StoredProcedure [dbo].
                            
123下一頁(yè)閱讀全文
您可能感興趣的文章:
  • SQLServer存儲(chǔ)過(guò)程中事務(wù)的使用方法
  • SQL SERVER調(diào)用存儲(chǔ)過(guò)程小結(jié)
  • 五種SQL Server分頁(yè)存儲(chǔ)過(guò)程的方法及性能比較
  • SQL Server存儲(chǔ)過(guò)程中使用表值作為輸入?yún)?shù)示例
  • 深入分析SQL Server 存儲(chǔ)過(guò)程
  • Java中調(diào)用SQL Server存儲(chǔ)過(guò)程詳解
  • 談?wù)剆qlserver自定義函數(shù)與存儲(chǔ)過(guò)程的區(qū)別
  • SQL Server 2008 存儲(chǔ)過(guò)程示例
  • SQLServer用存儲(chǔ)過(guò)程實(shí)現(xiàn)插入更新數(shù)據(jù)示例
  • c#實(shí)現(xiàn)sqlserver事務(wù)處理示例
  • SQL Server存儲(chǔ)過(guò)程中編寫(xiě)事務(wù)處理的方法小結(jié)

標(biāo)簽:晉中 珠海 東營(yíng) 南昌 煙臺(tái) 北海 石家莊 咸寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SqlServer 2000、2005分頁(yè)存儲(chǔ)過(guò)程整理第1/3頁(yè)》,本文關(guān)鍵詞  SqlServer,2000,2005,分頁(yè),存儲(chǔ),;如發(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)文章
  • 下面列出與本文章《SqlServer 2000、2005分頁(yè)存儲(chǔ)過(guò)程整理第1/3頁(yè)》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于SqlServer 2000、2005分頁(yè)存儲(chǔ)過(guò)程整理第1/3頁(yè)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    宁南县| 嘉荫县| 赤城县| 家居| 师宗县| 乌拉特后旗| 绥德县| 青铜峡市| 射阳县| 敖汉旗| 汪清县| 林芝县| 绥中县| 常德市| 三门峡市| 怀来县| 冀州市| 盐城市| 铅山县| 广汉市| 长白| 滕州市| 昌黎县| 南溪县| 辽阳县| 龙州县| 江安县| 西宁市| 江孜县| 读书| 济南市| 砀山县| 垦利县| 息烽县| 财经| 达州市| 阜康市| 手机| 道真| 应城市| 平山县|