Oracle查询rownum与rowid的不同之处

数据库 Oracle
在Oracle查询中rownum与rowid是我们经常用到的,以下的文章主要是介绍rownum与rowid在实际应用中的不同之处,以下就是正文的介绍。

以下的文章主要是介绍Oracle查询rownum与rowid的不同之处,以及以假设的方式即,查询条件为rownum = 2,在查询出第一条记录的时的具体内容的介绍,以下就是文章的详细内容的介绍。

在查询中,我们可以注意到,类似于

  1. select xx from table where rownum < n”(n>1) 

这样的查询是有正确含义的,而

  1. select xx from table where rownum = n” 

这样的查询只在n=1的时候成立,

  1. select xx from table where rownum > n”(n>1) 

这样的查询只能得到一个空集。

另外

  1. select xx from table where rownum > 0” 

这个查询会返回所有的记录。这是为什么呢?原因就在于Oracle对rownum的处理上,rownum是在得到结果集的时候产生的,用于标记结果集中结果顺序的一个字段,这个字段被称为“伪数列”,也就是事实上不存在的一个数列。

它的特点是按顺序标记,而且是逐次递加的,换句话说就是只有有rownum=1的记录,才可能有rownum=2的记录。

让我们回头来分析一下在where中使用rownum作为Oracle查询条件的情况。在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,而是取够数据就停止查询。

要验证这个想法应该很简单,找一个数据量非常大的表进行Oracle查询就可以了。可惜目前我没有这样的表。

我们可以看出,直接使用rownum是要受到限制的。但是很容易遇到这样的需求“查出符合条件的第xx条到第xx条记录”,比如页面的分页处理。这个时候如何构造出适合自己的结果集?嗯,墙边那位说全取出来手工挑选的哥们可以拉出去了。

当然这样做也是可以的,但是前提是整个数据集的数据条数不多的情况下。假如遇到上十万百条的数据,全部取出来的话,用户就不用干别的事情了。这个时候用户应该怎么做呢?当然就是要用到我们介绍的rownum拉!rownum不是个“伪数列”么,好说,我们现在把它弄成一个实在的字段就可以了。

具体做法就是利用子Oracle查询,在构建临时表的时候,把rownum也一起构造进去。比如

  1. select xx,yy from 
    (select xx,yy,rownum as xyz from table where zz 
    >20) 
    where xyz between 10 and 20” 

这样就可以了。

另外使用Oracle提供的结果集处理函数minus也可以做到,例如

  1. select xx,yy from table where zz > 20 and rownum 
    <20 minus select xx,yy from table where zz>20 and rownum <10” 

但是使用minus好像比使用子查询更加消耗资源。

和rownum相似,Oracle还提供了另外一个伪数列:rowid。不过rowid和rownum不同,一般说来每一行数据对应的rowid是固定而且唯一的,在这一行数据存入数据库的时候就确定了。可以利用rowid来查询记录,而且通过rowidOracle查询记录是查询速度最快的查询方法。

(这个我没有试过,另外要记住一个长度在18位,而且没有太明显规律的字符串是一个很困难的事情,所以我个人认为利用rowid查询记录的实用性不是很大)rowid只有在表发生移动(比如表空间变化,数据导入/导出以后),才会发生变化。

 

【编辑推荐】

  1. Oracle常用的命令中Oracl的相关数据类型列举
  2. Oracle删除后,重装方案有哪些
  3. 在Oracle SQL优化中经常使用的方案
  4. Oracle性能调整,提升block的效率
  5. Oracle性能调整的要点中的操作系统的优化
责任编辑:佚名 来源: 互联网
相关推荐

2010-04-20 16:07:25

Oracle DRCP

2010-05-06 10:09:44

Oracle in

2009-05-25 10:00:01

Oraclerownumrowid

2009-08-20 10:39:00

Java与C#的不同之

2012-08-23 13:36:27

2010-08-05 11:08:27

DB2存储过程

2010-04-20 14:32:49

Oracle LABE

2014-08-14 17:11:51

LinuxWindows

2023-08-10 17:23:10

LibreOfficOpenOffice

2009-12-15 18:47:56

Ruby框架OG

2012-08-31 11:21:12

云计算大数据

2009-11-26 19:18:59

PHP函数implod

2010-05-21 15:33:54

MySQL text

2021-03-09 16:38:48

加密货币比特币货币

2023-11-27 08:00:36

开发数据库查询

2010-09-27 10:43:35

无线路由器

2017-03-14 15:46:30

AndroidiOS不同之处

2010-05-21 15:53:30

2010-03-10 10:58:12

python接口功能

2010-02-06 09:31:42

C++函数对象
点赞
收藏

51CTO技术栈公众号