`
Supanccy2013
  • 浏览: 224977 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

oracle rownum 详解 rowid

阅读更多
1,针对
select * from scott.dept rownum > 0 查询出所有的记录
,而
     
 select * from scott.dept rownum > 1 
查询出空的解释:
   该内容来自互联网,因见解渗透,故在此引用:
   自己的总结原因三点:
   1),rownum是个伪劣
   2), rownum在一条记录查询后来之后加上去的伪劣。
   3), rownum先为1,在一次递增。

  
   在Oracle中,有一个很有趣的东西,那就是rownum。当你从某个表中查询数据的时候,返回的结果集中都会带有rownum这个字段,而且有时候也可以使用rownum进行一些条件查询。
   在查询中,我们可以注意到,类似于“select xx from table where rownum < n”(n>1)这样的查询是有正确含义的,而“select xx from table where rownum = n”这样的查询只在n=1的时候成立,“select xx from table where rownum > n”(n>1)这样的查询只能得到一个空集。另外“select xx from table where rownum > 0”这个查询会返回所有的记录。这是为什么呢?原因就在于Oracle对rownum的处理上,rownum是在得到结果集的时候产生的,用于标记结果集中结果顺序的一个字段,这个字段被称为“伪数列”,也就是事实上不存在的一个数列。它的特点是按顺序标记,而且是逐次递加的,换句话说就是只有有rownum=1的记录,才可能有rownum=2的记录。

  让我们回头来分析一下在where中使用rownum作为查询条件的情况。在rownum取=1,或者rownum <= n (n>1)的时候,没有问题。那么为什么当条件为rownum = n或者rownum >= n时明明有数据却只能得到一个空集呢?假设我们的查询条件为rownum = 2,那么在查询出的第一条记录的时候,oracle标记此条记录rownum为1,结果发现和rownum=2的条件不符,于是结果集为空。写到这里,我忽然有一个有趣的想法:假如有一条查询语句为select xx,yy from table where zz > 20 and rownum < 10,那么在执行的时候,是先按照zz>20的条件查询出一个结果集,然后按照rownum取出前10条返回?还是在按照zz>20的条件先查询,然后有一个记录就标记一个rownum,到rownum<10的时候就停止查询?我觉得应该是后者,也就是在执行语句的时候,不是做full scan,而是取够数据就停止查询。要验证这个想法应该很简单,找一个数据量非常大的表进行查询就可以了。可惜目前我没有这样的表。

  我们可以看出,直接使用rownum是要受到限制的。但是很容易遇到这样的需求“查出符合条件的第xx条到第xx条记录”,比如页面的分页处理。这个时候如何构造出适合自己的结果集?嗯,墙边那位说全取出来手工挑选的哥们可以拉出去了。当然这样做也是可以的,但是前提是整个数据集的数据条数不多的情况下。假如遇到上十万百条的数据,全部取出来的话,用户就不用干别的事情了。这个时候用户应该怎么做呢?当然就是要用到我们介绍的rownum拉!rownum不是个“伪数列”么,好说,我们现在把它弄成一个实在的字段就可以了。具体做法就是利用子查询,在构建临时表的时候,把rownum也一起构造进去。比如“select xx,yy from (select xx,yy,rownum as xyz from table where zz >20) where xyz between 10 and 20”这样就可以了。另外使用oracle提供的结果集处理函数minus也可以做到,例如“select xx,yy from table where zz > 20 and rownum <20 minus select xx,yy from table where zz>20 and rownum <10”,但是使用minus好像比使用子查询更加消耗资源。

2,和rownum相似,oracle还提供了另外一个伪数列:rowid。不过rowid和rownum不同,一般说来每一行数据对应的rowid是固定而且唯一的,在这一行数据存入数据库的时候就确定了。可以利用rowid来查询记录,而且通过rowid查询记录是查询速度最快的查询方法。(这个我没有试过,另外要记住一个长度在18位,而且没有太明显规律的字符串是一个很困难的事情,所以我个人认为利用rowid查询记录的实用性不是很大)rowid只有在表发生移动(比如表空间变化,数据导入/导出以后),才会发生变化。
分享到:
评论

相关推荐

    Oracle学习笔记(rownum和rowid)

    Oracle学习笔记(rownum和rowid),有具体的代码案例讲解rownum和rowid

    oracle_SQL中rowid与rownum的使用

    二、ROWNUM详解 `ROWNUM`是Oracle中的一个内置函数,它返回一个行号,表示当前行在查询结果集中的位置。其特点如下: 1. **动态生成**:`ROWNUM`是在查询执行时动态生成的,从1开始递增。 2. **限制结果**:可以...

    关于oracle的rownum

    Oracle ROWNUM 伪列详解 Oracle 的 ROWNUM 伪列是一个非常重要的概念,它对结果集加的一个伪列,即先查到结果集之后再加上去的一个列。了解 ROWNUM 的意义是非常重要的,否则可能会出现莫名其妙的结果。 ROWNUM ...

    oracle-rownum用法

    Oracle ROWNUM 用法详解 ROWNUM 是 Oracle 系统中一个伪列,用于对查询返回的行进行编号,从 1 开始,每行递增 1。ROWNUM 可以用于限制查询返回的总行数,但需要注意的是,ROWNUM 不能以任何表的名称作为前缀。 ...

    ORACLE数据库中ROWNUM用法详解

    6. **ROWID与ROWNUM的区别**:ROWID是Oracle数据库中另一个伪列,它标识表中每行的物理位置,是表空间中记录的唯一标识。ROWID是物理存在的,不会因查询顺序改变而变化,可以作为查询条件,不会出现ROWNUM那样的问题...

    Oracle DBA性能优化实践

    Hint.pdf Oracle中rowid与rownum的使用.pdf Oracle优化 之 索引.pdf Oracle优化器.pdf STATSPACK详解.pdf 学用ORACLE_AWR和ASH特性.pdf 执行计划.pdf

    oracle函数详解[收集].pdf

    - 伪列:Oracle系统自动生成的特殊列,如`ROWNUM`用于为查询结果集分配唯一的数字,`ROWID`是记录的唯一标识,`CURRVAL`和`NEXTVAL`与序列号生成有关,`LEVEL`在递归查询中表示层次。 - 伪表:DUAL表是一个特殊的...

    17.Oracle伪列1

    Oracle提供了两种主要的伪列:rowid和rownum,它们各自拥有独特的功能和用途。 一、rowid伪列 1. rowid原理 rowid是Oracle用来唯一标识表中每一行数据的物理地址,它是一个10字节的值,但在显示时以18字节的字符串...

    oracle的一些相关网页介绍

    在"rownum和rowid详解_平凡的三叶草_新浪博客.mht"中,可能会详细解释ROWNUM的使用方式,如限制返回结果的数量(如只取前N条记录)以及在分页查询中的作用。 3. **视图(View)**: Oracle视图是从一个或多个表或...

    oracle的伪列与分页

    #### 二、ROWID与ROWNUM详解 **ROWID:** - **定义**:ROWID是Oracle中用于唯一标识表中每一行记录的一个伪列。 - **特性**: - 每个表的每一行都有一个唯一的ROWID值。 - ROWID包含行的实际物理地址。 - 使用...

    Oracle函数详解

    Oracle函数详解涵盖了数据库管理系统Oracle中广泛使用的各种函数,这些函数对于数据处理和查询至关重要。在Oracle SQL中,函数被用来处理和操作数据,包括数学、字符串、日期、转换以及更复杂的聚合函数。以下是一些...

    oracle函数详解

    根据提供的文件内容,可以看出文档主要涉及的是Oracle SQL的基础语法与函数使用详解。下面将对文档中的各个知识点进行详细的解释和扩展。 ### Oracle SQL基础语法与函数详解 #### 1. 基本运算符 在Oracle SQL中,...

    oracle面试题

    以上就是关于Oracle中`RowID`、`RowNum`的使用方法,以及Oracle分页语句和存储过程的创建与使用的详细介绍。这些知识点对于Oracle开发人员来说非常重要,熟练掌握它们能够帮助你在实际工作中更高效地解决问题。

    Oracle语句优化53个规则详解.doc

    Oracle SQL 语句优化是数据库性能提升的关键环节,以下是对53个规则的详解中几个关键点的深入阐述: 1. 选择合适的优化器: ORACLE 提供三种优化器:基于规则(RULE)、基于成本(COST)和选择性(CHOOSE)。基于...

    Oracle数据库学习指南

    40. 如何正确利用Rownum来限制查询所返回的行数 41. 什么是ROWID,为什么需要它 42. 手工安装数据库时需要安装那些系统包 43. 手工创建数据库的全部脚本及说明 44. 提高Oracle数据库应用系统安全的举例与分析 ...

    30个Oracle语句优化规则详解

    - ROWID访问:通过索引快速定位记录,提高查询效率。创建和维护索引是提升性能的关键,特别是对于频繁查询的列。 3. 共享SQL语句 Oracle的共享池允许相同SQL语句的解析结果被复用,减少解析开销。SQL语句必须完全...

    oracle到sqlserver存储过程语法转换

    ### Oracle到SQL Server存储过程语法转换详解 在数据库迁移项目中,从Oracle迁移到SQL Server是一种常见的场景。本文旨在提供一份详细的指南,帮助开发者更好地理解这两种数据库系统在存储过程方面的语法差异,并...

Global site tag (gtag.js) - Google Analytics