首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网络编程-> 数据库教程
如何在sqlserver与oracel中进行分页的讨论!
作者:网友供稿 点击:38
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

使用sql,和oracle数据库进行分页可以有以下三种方法!


下面让我们看一看如果我们要在数据库中取第1000条到第1010条的数据这两种方法是怎么实现的.


1.        使用临时表的方法. (在系统中主要是直接写Sql语句来做)

 

a)          按所需的排序方式排好序

 

b)         创建临时表

 

c)          从数据库里取出第0条 到 第1010条的数据

 

d)         把这些数据放入临时表中

 

e)          把临时表再按与 a) 相反的排序方式排好序

 

f)          然后只需把临时表中的前10条显时出来

 

g)          销毁临时表

 


 


2.        使用 object 的方法

 

a)          按所需的排序方式排好序

 

b)         从数据库里取出第0条 到 第1010条的数据

 

c)          倒着从这1010条数据中取10条 放入一个 object中

 

d)         把这个 object里的记录 完全倒置一下

 

e)          把 object里的数据显示出来

 


 


显然 第二种 方法优于第一种方法 它减少了系统创建, 销毁临时表所需耗费的资源, 但是它们都有一个共同的弱点. 那就是 它们都要从数据库里取出第0条 到 第1010条的数据  这样就造成了 查询出的记录数很少,但网络传输数据量很大!

 


 


因此比较好的分页做法应该是:

 

每次翻页的时候只从数据库里检索页面大小的块区的数据。这样虽然每次翻页都需要查询数据库,但查询出的记录数很少,网络传输数据量不大,如果使用连接池更可以略过最耗时的建立数据库连接过程。而在数据库端有各种成熟的优化技术用于提高查询速度,比在应用服务器层做缓存有效多了。

 


 


对于SqlServer 数据库 如要到得第1000-1010条记录:

 


 


Select top 10  * from (

 

Select top 10  * from (

 

     Select top 1010 * from docdetail order by lastmodidate asc ,Id asc

 

) temptbl1 order by lastmodidate desc ,Id desc

 

) temptbl2 order by lastmodidate asc,Id asc

 

对于oracle 数据库 如要到得第1000-1010条记录 由于oracle中的rownum是在查询之后排序之前赋值的.所以其相应的写法应为:


 select * from (

 

         select my_table.*, rownum as temptbl_rownum from (

 

                   Select * from docdetail order by lastmodidate asc,Id asc

 

      ) temptbl where rownum <1010

 

 ) where  temptbl_rownum >=1000

 

 

当以上的Sql语句执行完成以后, 网络传输数据量就从以前的1010条减少到 10条


通过以上分页方式的改变,对我们系统的性能有很大的提升


我有个客户使用的是oracel数据库 其中文档数目为 12万条 ,当我们对这张表时行搜索的时候 使用第一种方法进行分页时,页面显示的时间约为10秒左右,而使用第三种方法而现在页面显示时间只需要2-3秒左右.

 

当然,可能还有更好的分页方法,总觉得随着数据库里的数据的不断增加,系统运行的速度将会变慢,我在这里贴出这篇文章,只是想和大家讨论一下,还有没有更好的方法, 希望大家不吝回复! 一起讨论!


:D (完)


[点击此处收藏本文]
发表于 2005年04月12日 9:35 AM


随便说说 发表于2005-04-14 2:42 PM 
1.
select my_table.*, rownum as temptbl_rownum from (
Select * from docdetail order by lastmodidate asc,Id asc
) temptbl where rownum <1010 and rownum >=1000

2.
select * from docdetail rownum <1010
minus
select * from docdetail rownum <1000


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·jsp留言板源代码4-JSP教程,数据库相关
·“脱衣秀”泛滥 四川打击淫秽色情视频聊天室
·c#中使用 crystal reports (水晶报表)的打包和部署问题-.NET教程,报表/图形/Office
·MDAC2.8 下载!-ASP教程,数据库相关
·数据库安装包的制作(参考MSDN)-.NET教程,安装和部署
·asp讲座之七:asp与数据库(二)
·深度和广度优先分油问题(C#实现)-.NET教程,C#语言
·C#在状态栏中,自绘进度条,-.NET教程,C#语言
·怎么清除sql server日志
·C#中的接口-.NET教程,C#语言
最新文章
·sql server 2005 ce基础概要_数据库教程
·用flash as代码制作按钮弹出窗口_flash教程
·alexa:戏曲性地调整_alexa排名
·google也推出域名注册_google推广
·技巧总结:div中class与id的区别及应用_css教程
·windows vista命令runas.exe全解析_windows vista
·photoshop将美女照片处理成仿古斑驳油画_photoshop教程
·百度主题推广代码的完全解析-知己知彼_网赚技巧
·你的google adsense帐号是否被人盗用?_网赚技巧
·如何挑出google adsense中单价极低的广告商_网赚技巧
相关主题
  • 如何在sqlserver2000中实现oracle的序列_数据库技巧
  • 如何在sqlserver中快速有条件删除海量数据_数据库技巧
  • 如何在SqlServer与oracel中进行分页的讨论!-JSP教程,Java技巧及代码
  • 如何在SQL中启用全文检索功能?(实例)-数据库专栏,SQL Server
  • 如何在SQL Server存储过程中执行DTS包-数据库专栏,SQL Server
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭