码迷,mamicode.com
首页 > 其他好文 > 详细

ROWNUM使用大于查不到值的问题(查询大于10小于21 范围内的数据)

时间:2018-08-27 21:33:15      阅读:296      评论:0      收藏:0      [点我收藏+]

标签:记录   where   数据库   jquer   main   sel   oracl   ace   detail   

转  https://blog.csdn.net/jquerys/article/details/52432770

第一种:

select t.*, rownum as rid from (
      select  *   from interface_log a,interface_key b,interface c  where  a.inte_log_key=b.intekey_key and   a.inte_log_mainuuid=c.inte_uuid ORDER BY inte_log_cdate desc

  ) t 
where rownum >10 and rownum <21

 

第二种:

select * from(
        select t.*, rownum as rid from (
               select  *  from sjzx_interface_log a,sjzx_interface_key b,sjzx_interface c  where  a.inte_log_key=b.intekey_key and  a.inte_log_mainuuid=c.inte_uuid ORDER BY inte_log_cdate desc

        ) t      

        where rownum <21 )
where rid >10

 

第一种会导致错误,

    因为rownum总是从1开始的,第一条不满足去掉的话,第二条的rownum 又成了1。依此类推,所以永远没有满足条件的记录。

    可以这样理解:rownum是一个序列,是Oracle数据库从数据文件或缓冲区中读取数据的顺序。

第二种先把前21条数据取出来,编号,再从编号中取出第10条之后的

ROWNUM使用大于查不到值的问题(查询大于10小于21 范围内的数据)

标签:记录   where   数据库   jquer   main   sel   oracl   ace   detail   

原文地址:https://www.cnblogs.com/hqsbrx/p/9543832.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!