Oracle rownum 浅析

ROWNUM是Oracle从8开始提供的一个伪列,是把SQL出来的结果进行编号,始终从1开始,常见的用途就是用来分页输出.

比如:

      SELECT * FROM  table_temp t WHERE ROWNUM <= 10   -- 该语句是查询前10条的记录,跟sqlserver top类似 ,但是rownum对应编号区间的查询更为强大
      SELECT * FROM (SELECT a.*, ROWNUM rn  FROM table_temp t) WHERE rn >= 10 AND rn <= 20  --查询第10-20条记录 ,。
              这里之所以rownum rn, 是把rownum转成实例,因为rownum本身只能用 <=的比较方式,只有转成实列,这样就可做 >=的比较了

              ROWNUM结合排序的使用:

       SELECT * FROM (SELECT t.*  FROM table_temp t  ORDER BY date DESC)  WHERE ROWNUM <= 10    --语句1
      SELECT t.*  FROM table_temp t  WHERE ROWNUM <= 10  ORDER BY date DESC                    --语句2

             之所以会出现这样的语句,主要是从效率上的考虑,语句1,是要进行全表扫描后再排序,然后再取10条纪录,语句2则不会全表扫描,只会取出10条纪录, 很明显

             后条语句的效率会高许多.不过两种顺序取出来的结果是截然相反的,Oracle查询前10条记录时先排序再取10条,就是取最近的10条,而先取10条,再排序,则取出的

             最早的10条纪录。对于语句2,普遍的认为执行顺序是先取10条纪录再排序的。所以语句2应该是错误.但实际上并非如此,此语句的执行顺序和order by的字段有关系,

             如果你order by 的字段是pk,则是先排序,再取10条(速度比第一种语句快),而排序字段不是PK 时,是先取10条再排序,此时结果就与要求不一样了,所以第二种

             写法一定要在排序字段是主键的情况下才能保证结果正确。

    Row_number() over()这个分析函数是从9I开始提供的,一般的用途和rownum差不多。

    一般写法row_number() over( order by order_date desc) 生成的顺序和rownum的语句一样,效率也一样(对于同样有order by 的rownum语句来说),所以在这种

    情况下两种用法是一样的。而对于分组后取最近的10条纪录,则是rownum无法实现的,这时只有row_number可以实现,row_number() over(partition by 分组字段 order by 排序字段)就能实现

    分组后编号,比如说要取近一个月的每天最后10个订单纪录.

SELECT * FROM (SELECT t.*,  ROW_NUMBER () OVER (PARTITION BY TRUNC (order_date) ORDER BY order_date DESC) rn FROM table_temp t)  WHERE rn <= 10

             Rownum的另类用法,有时候我们会遇到这种需求,要求输出当月的所有天数,许多人会烦恼,数据库里又没有这样的表,怎么输出一个月的所有天数呢?  用rownum就能解决:

       SELECT TRUNC (SYSDATE, 'MM') + ROWNUM - 1  FROM DUAL  CONNECT BY ROWNUM <= TO_NUMBER (TO_CHAR (LAST_DAY (SYSDATE), 'dd')) 

            综上所述:oracle查询第5条到第10记录分页查询为:

      select * from (select t.*,rownum rn from (select * from scott.emp) t where rownum<=10) where rn>=5;


 



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值