设为首页 收藏本站
查看: 890|回复: 0

[经验分享] oracle-rownum的理解

[复制链接]

尚未签到

发表于 2018-9-14 10:51:43 | 显示全部楼层 |阅读模式
  rownum是什么?
  rownum是一个伪列,在表中不是真实存在的
  rownum是oracle从数据文件或者缓冲区读取数据的一个顺序
  如果想得到一个表中第二行的数据,按照select * from test where rownum=1;这个查询,查询得到的数据不是正确的,而且只能是在=1时能查出数据,在等于其他值的时候是查不出任何数据的
  rownum只能跟小于等于,不能跟大于,如果要大于需要和小于同时使用
  rownum工作原理:
  由于表中没有行号,因此是不能查询到第几行的数据的
  首先,标准的 SQL 的解析顺序为:
  (1).FROM 子句, 组装来自不同数据源的数据
  (2).WHERE 子句, 基于指定的条件对记录进行筛选
  (3).GROUP BY 子句, 将数据划分为多个分组
  (4).使用聚合函数进行计算
  (5).使用 HAVING 子句筛选分组
  (6).计算所有的表达式
  (7).使用 ORDER BY 对结果集进行排序
  (8).最后是select ,执行查询
  rownum是在执行的查询语句执行谓词之后且在完成排序或者簇集之前赋予值的,在分配后值加1
  既在有select 、from 、where 、group by 、having、order by 的查询中,先后执行顺序是:
  from/where -> rownum(这个是从from/where结果中分配给每个行rownum并且增加1) -> select -> group by -> having -> order by
  因为oracle会把执行查询的得到的第一个符合条件的结果rownum加1,而不符合条件的会仍掉,如果符合条件会在后面+1,而执行select * from test where rownum>1;而条件是>1,而1不是大于1的,就依次推全表扫表没有符合条件的值,所以这句话永远都查询不出来结果的!!!!
  执行select * from test where rownum>1;这句话的执行计划:
SYS@u01>select * from test where rownum>1;  
no rows selected
  
Elapsed: 00:00:00.08
  
Execution Plan
  
----------------------------------------------------------
  
Plan hash value: 2091529335
  
----------------------------------------------------------------------------

  
|>  
----------------------------------------------------------------------------
  
|   0 | SELECT STATEMENT    |      | 69115 |    13M|   294   (1)| 00:00:04 |
  
|   1 |  COUNT          |      |       |       |        |      |
  
|*  2 |   FILTER        |      |       |       |        |      |
  
|   3 |    TABLE ACCESS FULL| TEST | 69115 |    13M|   294   (1)| 00:00:04 |
  
----------------------------------------------------------------------------

  
Predicate Information (identified by operation>  
---------------------------------------------------
  
2 - filter(ROWNUM>1)
  
Note
  
-----
  
- dynamic sampling used for this statement (level=2)
  
Statistics
  
----------------------------------------------------------
  
49  recursive calls
  
0  db block gets
  
1267  consistent gets
  
1363  physical reads

  
0  redo>  
1343  bytes sent via SQL*Net to client
  
512  bytes received via SQL*Net from client
  
1  SQL*Net roundtrips to/from client
  
4  sorts (memory)
  
0  sorts (disk)
  
0  rows processed
  首先是TABLE ACCESS FULL.....
  因为是先得到符合条件的行,再为符合条件的行对其赋予rownum  ,在得到的行一次+1赋值,所以查出来的是1.2.3.....n.
  例如对于emp表如果想知道薪水排在前5行的人的信息,执行:select * from emp where rownum5的去掉前5行数据(这里使用的rn别名,是剩下10行的那个rownum,为了不与最外层的那个rownum冲突),然后得到的就是中间的排序后第5到10行数据
  为了好理解,查询弄多个别名:
SCOTT@u01>select rownum,rn,re FROM (Select rownum rn ,b.* from (select rownum re,e.* from emp e order by ename desc) b where rownum5;  
ROWNUM     RN         RE
  
---------- ---------- ----------
  
1      6          5
  
2      7          9
  
3      8          4
  
4      9         12
  
Elapsed: 00:00:00.03
  
SCOTT@u01>
  set autot on;
  既显示查询的结果,也显示执行计划、执行路径、统计信息
  set autot trace
  不显示查询的结果,只显示执行计划、执行路径、统计信息



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-582351-1-1.html 上篇帖子: Oracle Enterprise linux(OEL)官方yum源配置 下篇帖子: Oracle技术之TOPAS 命令详解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表