Sybase分页显示存储过程


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

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

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

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

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

<span style="background-color: rgb(255, 255, 255);">CREATE procedure pagination1  
 
(@pagesize int,   --页面大小,如每页存储20条记录  
 
@pageindex int    --当前页码  
 
)  
 
as  
 
set nocount on  
 
begin  
 
declare @indextable table(id int identity(1,1),nid int)   --定义表变量  
 
declare @PageLowerBound int   --定义此页的底码  
 
declare @PageUpperBound int   --定义此页的顶码  
 
set @PageLowerBound=(@pageindex-1)*@pagesize  
 
set @PageUpperBound=@PageLowerBound+@pagesize  
 
set rowcount @PageUpperBound  
 
insert into @indextable(nid) select gid from TGongwen where fariqi >dateadd(day,-365,getdate()) order by fariqi desc  
 
select O.gid,O.mid,O.title,O.fadanwei,O.fariqi from TGongwen O,@indextable t where O.gid=t.nid  
 
and t.id>@PageLowerBound and t.id<=@PageUpperBound order by t.id  
 
end  
 
set nocount off  </span>



Reference:

http://database.51cto.com/art/201011/235488.htm

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值