ITPub博客

首页 > Linux操作系统 > Linux操作系统 > rownum新发现

rownum新发现

原创 Linux操作系统 作者:DJxiaoyang 时间:2009-02-24 13:54:33 0 删除 编辑

笔者在工作中有一上百万条记录的表,在jsp页面中需对该表进行分页显示, 便考虑用rownum来作,下面是具体方法(每页 显示20条): “select * from tabname where rownum<20 order by name" 但却发现oracle却不能按自己的意愿来执行,而是先随便 取20条记录,然后再 order by,后经咨询oracle,说rownum确实就这样,想用的话,只能用子查询 来实现先排序,后 rownum,方法如下: "select * from (select * from tabname order by name) where rownum<20",但这样一来,效率会较低很多。 后经笔者试验,只需在order by 的字段上加主键或索引即可让oracle先按 该字段排序,然后再rownum;方法不变: “select * from tabname where rownum<20 order by name" 经笔者反复验证,都没有问题。


/*************************************************\
|  上例仅适用于查询,不可求和    |
\*************************************************/
例:  xfzje 索引
select xfzje from hy_hyxxb where rownum<9450 order by xfzje desc;

上句查询结果正确

select sum(xfzje) from hy_hyxxb where rownum<9450 order by xfzje desc;

但是这个求和就不正确,

select sum(xfzje) from (select xfzje from hy_hyxxb where rownum<9450 order by xfzje desc);

这样写才可以!!!


 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8024375/viewspace-557558/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 没有了~
下一篇: 没有了~
请登录后发表评论 登录
全部评论

注册时间:2009-02-24

  • 博文量
    1
  • 访问量
    1426