数据库

本类阅读TOP10

·SQL语句导入导出大全
·SQL Server日期计算
·SQL语句导入导出大全
·SQL to Excel 的应用
·Oracle中password file的作用及说明
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·sqlserver2000数据库置疑的解决方法
·一个比较实用的大数据量分页存储过程
·如何在正运行 SQL Server 7.0 的服务器之间传输登录和密码
·SQL中两台服务器间使用连接服务器

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
关于使用存储过程创建分页

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

2005-1-4
关于使用存储过程创建分页

    今天查询有关sql server 索引的资料 无意在一篇文章的末尾发现一个关于使用存储过程创建分页的代码,直接复制到查询分析器里有误,整理调试了一个,搬上来一起学习一下。

    注:原作者 freedk  以下为笔者整理 这是一个相对最优的方法在大量数据集中表现突出
    
    建立一个 Web 应用,分页浏览功能必不可少。这个问题是数据库处理中十分常见的问题。经典的数据分页方法是:ADO 纪录集分页法,也就是利用ADO自带的分页功能(利用游标)来实现分页。但这种分页方法仅适用于较小数据量的情形,因为游标本身有缺点:游标是存放在内存中,很费内存。游标一建立,就将相关的记录锁住,直到取消游标。游标提供了对特定集合中逐行扫描的手段,一般使用游标来逐行遍历数据,根据取出数据条件的不同进行不同的操作。而对于多表和大表中定义的游标(大的数据集合)循环很容易使程序进入一个漫长的等待甚至死机。
  更重要的是,对于非常大的数据模型而言,分页检索时,如果按照传统的每次都加载整个数据源的方法是非常浪费资源的。现在流行的分页方法一般是检索页面大小的块区的数据,而非检索所有的数据,然后单步执行当前行。

    思路来源:
    从publish 表中取出第 n 条到第 m 条的记录:
    SELECT TOP m-n+1 *
      FROM publish
      WHERE (id NOT IN
              (SELECT TOP n-1 id
             FROM publish))

    存储过程:

CREATE PROCEDURE pagination3
@tblName varchar(255) , -- 表名
@strGetFields varchar(1000) = '*', -- 需要返回的列
@fldName varchar(255)='', -- 排序的字段名
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@doCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(1500) = '' -- 查询条件 (注意: 不要加 where)
AS

declare @strSQL varchar(5000) -- 主语句
declare @strTmp varchar(110) -- 临时变量
declare @strOrder varchar(400) -- 排序类型

if @doCount != 0
   begin
      if @strWhere !=''
         set @strSQL = 'select count(*)  Total from  where '+@strWhere
      else
         set @strSQL = 'select count(*)  Total from '
   end
--以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况:

else
   begin
      if @OrderType != 0
         begin
            set @strTmp = '<(select min'
            set @strOrder = ' order by [' + @fldName +'] desc'
         --如果@OrderType不是0,就执行降序,这句很重要!

         end
      else
         begin
            set @strTmp = '>(select max'
            set @strOrder = ' order by [' + @fldName +'] asc'
         end

     if @PageIndex = 1
        begin
           if @strWhere != ''

              set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from [' + @tblName + '] where ' + @strWhere + ' ' + @strOrder
           else

              set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from ['+ @tblName + '] '+ @strOrder
      --如果是第一页就执行以上代码,这样会加快执行速度
        end
     else
         begin
           set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from ['
                        + @tblName + '] where [' + @fldName + ']' + @strTmp + '(['
                        + @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
                        + @fldName + ']  from [' + @tblName + ']' + @strOrder + ') as tblTmp)'
                        + @strOrder

           if @strWhere != ''
             set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from ['
                        + @tblName + '] where [' + @fldName + ']' + @strTmp + '(['
                        + @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
                        + @fldName + '] from [' + @tblName + '] where ' + @strWhere + ' '
                        + @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
         end
   end
exec (@strSQL)
--print @strSQL
GO


以上代码在winxp_sp2   sql server2000 personal 下调试通过




相关文章

相关软件