国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

sql server 2005分頁存儲過程和sql server 2000分頁存儲過程

2024-08-31 00:53:04
字體:
來源:轉載
供稿:網友

sql server 2005分頁存儲過程和sql server 2000分頁存儲過程,sql 2005的分頁存儲過程分3個版本,一個是沒有優化過的,一個是優化過的,最后一個支持jion的,sql2000的分頁存儲過程,也可以運行在sql2005上,但是性能沒有sql2005的版本好。

http://www.svnhost.cn 版權所有,禁止轉載

USE [svnhost]

GO

/****** 對象:  StoredPRocedure [dbo].[up_Page2005]    腳本日期: 05/21/2008 11:27:05 ******/

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,--條件語句(不用加where)

 @pageSize int,                    --每頁多少條記錄

 @pageIndex int = 1 ,            --指定當前為第幾頁

 @TotalPage int output            --返回總頁數

as

begin


Begin Tran --開始事務

 

Declare @sql nvarchar(4000);

Declare @totalRecord int;


--計算總記錄數

 

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--計算總記錄數       

 

--計算總頁數

    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

 

--處理頁數超出范圍情況

    if @PageIndex<=0

Set @pageIndex = 1


if @pageIndex>@TotalPage

Set @pageIndex = @TotalPage


--處理開始點和結束點

    Declare @StartRecord int

Declare @EndRecord int


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

set @EndRecord = @StartRecord + @pageSize - 1


--繼續合成sql語句

    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 ---返回記錄總數

      End

end

 

 


GO

/****** 對象:  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,--條件語句(不用加where)

 @pageSize int,                    --每頁多少條記錄

 @pageIndex int = 1 ,            --指定當前為第幾頁

 @totalRecord int = 0,

@TotalPage int output            --返回總頁數

AS

BEGIN


Begin Tran --開始事務

 

Declare @sql nvarchar(4000);


if @totalRecord<=0 begin

--計算總記錄數

 

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--計算總記錄數      

    end


--計算總頁數

    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

 

--處理頁數超出范圍情況

    if @PageIndex<=0

Set @pageIndex = 1


if @pageIndex>@TotalPage

Set @pageIndex = @TotalPage


--處理開始點和結束點

    Declare @StartRecord int

Declare @EndRecord int


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

set @EndRecord = @StartRecord + @pageSize - 1


--繼續合成sql語句

    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 ---返回記錄總數

      End

END

 

GO

/****** 對象:  StoredProcedure [dbo].[up_Page2005V2_Join]    腳本日期: 05/21/2008 11:27:30 ******/

SET ANSI_NULLS ON

GO

SET QUOTED_IDENTIFIER ON

GO

-- =============================================

-- Author:        <Author,,Name>

-- Create date: <Create Date,,>

-- Description:    <Description,,>

-- =============================================

CREATE PROCEDURE [dbo].[up_Page2005V2_Join]

@TableName varchar(150),        --表名

 @Fields varchar(5000) = '*',    --字段名(全部字段為*)

 @OrderField varchar(5000),        --排序字段(必須!支持多字段)

 @sqlWhere varchar(5000) = Null,--條件語句(不用加where)

 @pageSize int,                    --每頁多少條記錄

 @pageIndex int = 1 ,            --指定當前為第幾頁

 @totalRecord int = 0,

@TotalPage int output            --返回總頁數

AS

BEGIN


Begin Tran --開始事務

 

Declare @sql nvarchar(4000);


if @totalRecord<=0 begin

--計算總記錄數

 

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--計算總記錄數      

    end


--計算總頁數

    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

 

--處理頁數超出范圍情況

    if @PageIndex<=0

Set @pageIndex = 1


if @pageIndex>@TotalPage

Set @pageIndex = @TotalPage


--處理開始點和結束點

    Declare @StartRecord int

Declare @EndRecord int


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

set @EndRecord = @StartRecord + @pageSize - 1


--繼續合成sql語句

    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 ---返回記錄總數

      End

END

 


 

 

USE [game]

GO

/****** 對象:  StoredProcedure [dbo].[page]    腳本日期: 05/21/2008 11:37:12 ******/

SET ANSI_NULLS ON

GO

SET QUOTED_IDENTIFIER ON

GO


CREATE proc [dbo].[page]

@RecordCount int output,

@ReturnCount bit,

@QueryStr nvarchar(1000)='table1',--表名、視圖名、查詢語句

@PageSize int=20,  --每頁的大小(行數)

@PageCurrent int=2,  --要顯示的頁 從0開始

@FdShow nvarchar (2000)='*', --要顯示的字段列表

@IdentityStr nvarchar (100)='id', --主鍵

@WhereStr nvarchar (2000)='1=1',

@FdOrder nvarchar(100)='desc' --排序    只能取desc或者asc

as


set nocount on


declare


@sql nvarchar(2000)

 

if @WhereStr = '' begin

set @WhereStr = '1=1'

end


if @ReturnCount=1 begin

declare @tsql nvarchar(200)

set @tsql=N'select @RecordCount = count(*) from ' + @QueryStr + ' where ' + @WhereStr

exec sp_executesql @tsql,N'@RecordCount int output',@RecordCount output

end


if @PageCurrent = 0 begin

set @sql = 'select top ' + cast(@PageSize as nvarchar(3)) + ' ' + @FdShow + ' from ' + @QueryStr + ' where ' + @WhereStr + ' order by ' + @IdentityStr + ' ' + @FdOrder

end


else begin

if upper(@FdOrder) = 'DESC' begin

set @sql = 'select top ' + cast(@PageSize as nvarchar(3)) + ' ' + @FdShow + ' from ' + @QueryStr + ' where ' + @WhereStr + ' and ' + @IdentityStr + '< ( select min(' + @IdentityStr + ') from (select top ' + cast(@PageSize*@PageCurrent as nvarchar(10)) + ' ' + @IdentityStr + ' from ' + @QueryStr + ' where ' + @WhereStr + ' order by ' + @IdentityStr + ' desc) as t) order by ' + @IdentityStr + ' desc'

end

else begin

set @sql = 'select top ' + cast(@PageSize as nvarchar(3)) + ' ' + @FdShow + ' from ' + @QueryStr + ' where ' + @WhereStr + ' and ' + @IdentityStr + '> ( select max(' + @IdentityStr + ') from (select top ' + cast(@PageSize*@PageCurrent as nvarchar(10)) + ' ' + @IdentityStr + ' from ' + @QueryStr + ' where ' + @WhereStr + ' order by ' + @IdentityStr + ' asc) as t) order by ' + @IdentityStr + ' asc'

end

end

--print @sql

execute(@sql)

--select @t = datediff(ms,@t1,getdate())---------------------

 

http://www.svnhost.cn/Article/Detail-81.shtml


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 棋牌| 东莞市| 育儿| 谷城县| 左权县| 迁西县| 轮台县| 自贡市| 辽阳县| 禹州市| 大足县| 丽江市| 白河县| 古蔺县| 青岛市| 阿拉善左旗| 辽宁省| 陇西县| 宜州市| 宜城市| 芒康县| 太湖县| 察哈| 濮阳市| 和静县| 龙胜| 慈溪市| 岑巩县| 镇巴县| 连城县| 丹阳市| 湟中县| 海丰县| 潮安县| 库尔勒市| 大田县| 清徐县| 东莞市| 昌都县| 德令哈市| 石家庄市|