SqlServer 2000、2005分页存储过程整理第1/3页

sql server 2005的分页存储过程分3个版本,一个是没有优化过的,一个是优化过的,最后一个支持join的,sql server 2000的分页存储过程,也可以运行在sql server 2005上,但是性能没有sql server 2005的版本好。

在最后 我还附带了一个二分法的分页存储过程,也很好用的说哈~~

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,--条件语句(不用加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

2.Sql Server 2005:

/****** 对象: StoredProcedure [dbo].[up_Page2005V2]  脚本日期: 05/21/2008 11:27:15 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:    
-- Create date: 
-- 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

3.Sql Server 2005:

/****** 对象: 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,--条件语句(不用加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

4.Sql Server 2000:

USE [game]
GO
/****** 对象: StoredProcedure [dbo].
            
   
   
   
   
1 2 3 下一页 阅读全文
  • SqlServer
  • 2000
  • 2005
  • 分页
  • 存储过程

相关文章

  • SqlServer 2000、2005分页存储过程整理第1/3页_第1张图片

    如何在SQL Server中使用随机记录集

    这篇文章介绍了如何在SQL Server里使用随机记录集,需要的朋友可以参考下
    2015-07-07
  • SqlServer 2000、2005分页存储过程整理第1/3页_第2张图片

    Sql Server 如何去掉内容里面的Html标签

    这篇文章主要介绍了Sql Server 去掉内容里边的Html标签的实现方法,代码超简单,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-05-05
  • SqlServer 2000、2005分页存储过程整理第1/3页_第3张图片

    如何监测和优化OLAP数据库

    微软SQL Server分析服务(SSAS)提供了一个用来创建和管理数据挖掘应用和在线分析处理系统的强大引擎,你应该仔细的监测和优化OLAP数据库和潜在的关系数据源。
    2015-09-09
  • SqlServer 2000、2005分页存储过程整理第1/3页_第4张图片

    SQL Server数据汇总五招轻松搞定

    有些时候你想让SQL Server 返回一个聚集结果集合,而不是一个详细的结果集。SQL Server的GROUPBY子句,为你提供了一种聚合SQL Server数据的方式。GROUPBY子句允许你在一列或多列数据甚至是表达式上进行分组操作,在这篇文章中,我将讨论如何使用GROUPBY子句来汇总数据。
    2015-09-09
  • SqlServer 2000、2005分页存储过程整理第1/3页_第5张图片

    SQL Server视图的讲解

    今天小编就为大家分享一篇关于SQL Server视图的讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • SqlServer 2000、2005分页存储过程整理第1/3页_第6张图片

    SQL Server纵表与横表相互转换的方法

    这篇文章主要介绍了SQL Server纵表与横表相互转换的方法,本文通过图文并茂的形式给大家介绍,介绍的非常详细,具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-09-09
  • SqlServer 2000、2005分页存储过程整理第1/3页_第7张图片

    基于存储过程的详细介绍

    本篇文章小编将为大家介绍,基于存储过程的详细介绍,有需要的朋友可以参考一下
    2013-04-04
  • SqlServer 2000、2005分页存储过程整理第1/3页_第8张图片

    SQL Server高可用的常见问题分析

    SQL Server高可用不就是微软的那几个技术吗,如Replication, Failover Clustering,本文将详细介绍,有需求的朋友可以参考下
    2012-11-11
  • SqlServer 2000、2005分页存储过程整理第1/3页_第9张图片

    case 嵌套查询与连接查询你需要懂得

    Case 子查询连接查询在sql开发中很常用的一个查询功能,感兴趣的你可不要错过本文,接下来为你详细介绍下
    2013-02-02
  • SqlServer 2000、2005分页存储过程整理第1/3页_第10张图片

    SQL SERVER的优化建议与方法

    SQL SERVER的优化建议与方法...
    2007-03-03

最新评论

你可能感兴趣的:(SqlServer 2000、2005分页存储过程整理第1/3页)