Oracle分页(转载)

1.一个通用的格式如下:

    --rownum 是记录序号(1,2,3...),
    --注意:如果 SQL 语句中有 ORDER BY ... 排序的时候,rownum 居然是先“标号”后排序。

SELECT * FROM 
( 
    SELECT A.*, rownum r FROM 
    ( 
        SELECT * FROM table_name ORDER BY PubTime DESC 
        --排序只能写在这里,不能写在外面,要特别小心。
     ) A 
     WHERE rownum <= 10 
) B 
WHERE r > 5;

 2.如果不需要排序,则可以少一层嵌套:

select * from 
(
   select rownum r,tablename.* from tablename 
   --这里就算有排序,事实上也没用。
)
where r between 10 and 20;

 3.简单的查找最大值或最小值时,也可以这样:

 

--取最大的
select * from   
(
   select * from  table_name order by id desc,place_id  desc
)   
where rownum<5;   

--取最小的
select * from   
(
   select * from  table_name order by id asc,place_id  asc
)   
where rownum<5;
   

     从一篇CSDN博客上找到的,觉得挺有用,所以自己记下来。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值