ORACLE中用rownum分页并排序的SQL语句

Oracle中使用rownum进行分页查询时,需要确保正确的排序。传统的ROWNUM+ORDER BY方式可能导致排序错误。通过在外层添加SELECT并限制ROWNUM范围,可以解决此问题。示例展示了如何获取第21至40条记录,并讨论了两种分页查询方法的效率差异。
摘要由CSDN通过智能技术生成

ORACLE中用rownum分页并排序的SQL语句

以前分页习惯用这样的SQL语句:

select * from
   (select t.*,rownum row_num from mytable t order by t.id) b
where b.row_num between 1 and 10

结果发现由于该语句会先生成rownum 后执行order by 子句,因而排序结果根本不对,后来在GOOGLE上搜到一篇文章,原来多套一层select 就能很好的解决该问题,特此记录,语句如下:

select * from
   (select a.*,rownum row_num from
      (select * from mytable t order by t.id desc) a
   ) b
where b.row_num between 1 and 10


==== 参考 ====

Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用。分页查询格式:

SELECT * FROM
    (
       SELECT A.*, ROWNUM RN
       FROM (SELECT * FROM TABLE_NAME) A
       WHERE ROWNUM <= 40
    )
WHERE RN >= 21

其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM <= 40和RN >= 21控制分页查询的每页的范围。

 

上面给出的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值