Sybase分页显示存储过程
创始人
2024-07-18 10:00:40
0

实现Sybase分页显示存储过程是我们经常会遇到的问题,下面就对Sybase分页显示存储过程的方法进行详细介绍,供您参考。

建立一个web应用,分页浏览功能必不可少。这个问题是数据库处理中十分常见的问题。经典的数据分页方法是:ADO 纪录集分页法,也就是利用ADO自带的分页功能(利用游标)来实现分页。但这种分页方法仅适用于较小数据量的情形,因为游标本身有缺点:游标是存放在内存中,很费内存。游标一建立,就将相关的记录锁住,直到取消游标。游标提供了对特定集合中逐行扫描的手段,一般使用游标来逐行遍历数据,根据取出数据条件的不同进行不同的操作。而对于多表和大表中定义的游标(大的数据集合)循环很容易使程序进入一个漫长的等待甚至死机。

更重要的是,对于非常大的数据模型而言,分页检索时,如果按照传统的每次都加载整个数据源的方法是非常浪费资源的。现在流行的分页方法一般是检索页面大小的块区的数据,而非检索所有的数据,然后单步执行当前行。

最早较好地实现这种根据页面大小和页码来提取数据的方法大概就是“俄罗斯存储过程”。这个存储过程用了游标,由于游标的局限性,所以这个方法并没有得到大家的普遍认可。

下面的存储过程就是结合我们的办公自动化实例写的Sybase分页存储过程:

  1. CREATE procedure pagination1  
  2.  
  3. (@pagesize int,   --页面大小,如每页存储20条记录  
  4.  
  5. @pageindex int    --当前页码  
  6.  
  7. )  
  8.  
  9. as  
  10.  
  11. set nocount on  
  12.  
  13. begin  
  14.  
  15. declare @indextable table(id int identity(1,1),nid int)   --定义表变量  
  16.  
  17. declare @PageLowerBound int   --定义此页的底码  
  18.  
  19. declare @PageUpperBound int   --定义此页的顶码  
  20.  
  21. set @PageLowerBound=(@pageindex-1)*@pagesize  
  22.  
  23. set @PageUpperBound=@PageLowerBound+@pagesize  
  24.  
  25. set rowcount @PageUpperBound  
  26.  
  27. insert into @indextable(nid) select gid from TGongwen where fariqi >dateadd(day,-365,getdate()) order by fariqi desc  
  28.  
  29. select O.gid,O.mid,O.title,O.fadanwei,O.fariqi from TGongwen O,@indextable t where O.gid=t.nid  
  30.  
  31. and t.id>@PageLowerBound and t.id<=@PageUpperBound order by t.id  
  32.  
  33. end  
  34.  
  35. set nocount off  
  36.  

以上存储过程运用了SQL SERVER的最新技术――表变量。应该说这个存储过程也是一个非常优秀的分页存储过程。当然,在这个过程中,您也可以把其中的表变量写成临时表:CREATE TABLE #Temp。但很明显,在SQL SERVER中,用临时表是没有用表变量快的。所以刚开始使用这个存储过程时,感觉非常的不错,速度也比原来的ADO的好。

 

 

【编辑推荐】

简单商讨Oracle Sybase数据库

Sybase数据库修复的两种情况

Sybase数据灾难方案浅析

sybase分页存储过程的实现

Sybase数据仓库大鹏证券应用案例

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...