欢迎光临
我们一直在努力

如何在SqlServer与oracel中进行分页的讨论!-JSP教程,Java技巧及代码

建站超值云服务器,限时71元/月

使用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 (完)

 

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 如何在SqlServer与oracel中进行分页的讨论!-JSP教程,Java技巧及代码
分享到: 更多 (0)

相关推荐

  • 暂无文章