`
pterodactyl
  • 浏览: 766601 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Oracle中查询rownum和rowid的区别

阅读更多
Oracle中查询rownum和rowid的区别



http://database.51cto.com


   2009-05-25 10:00   ljh0242   51CTO博客   我要评论(



0

)









    摘要:

    在Oracle中,有一个很有趣的东西,那就是rownum。当你从某个表中查询数据的时候,返回的结果集中都会带有rownum这个字段,而且有时候也可以使用rownum进行一些条件查询。

    标签:

    Oracle


      rownum


      rowid






    Oracle帮您准确洞察各个物流环节












在查询中,我们可以注意到,类似于“select xx from table



where rownum 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 1)的时候,没有问题。那么为什么当条件为rownum = n或者rownum >=

n时明明有数据却只能得到一个空集呢?假设我们的查询条件为rownum =

2,那么在查询出的第一条记录的时候,oracle标记此条记录rownum为1,结果发现和rownum=2的条件不符,于是结果集为空。写到这里,我

忽然有一个有趣的想法:假如有一条查询语句为select xx,yy from table where zz > 20 and

rownum 20的条件查询出一个结果集,然后按照rownum取出前10条返回?还是在按照zz>20的条件先

查询,然后有一个记录就标记一个rownum,到rownum20) where xyz between 10

and 20”这样就可以了。另外使用oracle提供的结果集处理函数minus也可以做到,例如“select xx,yy from table

where zz > 20 and rownum 20 and rownum 巧用dbms_rowid包获得rowid的详细信息





浅析Oracle中的表空间查询方法





Oracle数据库中的字符处理技巧








[/list]

【责任编辑:彭凡

TEL:(010)68476606】

分享到:
评论

相关推荐

    Oracle学习笔记(rownum和rowid)

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

    在oracle中灵活使用Rownum和rowId

    在Oracle数据库中,`ROWNUM` 和 `ROWID` 是两个非常重要的概念,它们可以帮助我们在查询数据时实现更灵活的数据管理。本文将详细介绍这两个概念的区别及其使用方法,并通过示例来帮助读者更好地理解。 #### 一、...

    Oracle查询语句中rownum与rowid的不同之处分析

    本文主要是以实例形式介绍了Oracle查询中rownum与rowid的不同之处,以及以假设的方式为例,查询条件为rownum = 2,在查询出第一条记录时的具体内容的介绍。 在查询中,我们可以注意到,类似于 select xx from ...

    oracle_SQL中rowid与rownum的使用

    在Oracle SQL中,`ROWID`和`ROWNUM`是两个非常重要的概念,它们在数据库查询和数据操作中起着至关重要的作用。本文将详细探讨这两个特性,包括它们的定义、用途以及如何在实际场景中有效利用它们。 一、ROWID详解 `...

    oracle_SQL中ROWID与ROWNUM的使用

    ### Oracle SQL中ROWID与ROWNUM的使用 #### ROWNUM 的使用——TOP-N 分析 在 Oracle SQL 中,`ROWNUM` 是一种特殊的伪列,用于标识查询结果集中的行编号。它常用于实现 TOP-N 查询,即返回结果集中满足特定条件的...

    oracle_SQL-rowid--rownum.zip_oracle

    在实际开发中,理解并合理利用`ROWID`和`ROWNUM`,可以有效地提升Oracle数据库的管理和查询效率。同时,从提供的压缩文件名来看,除了`oracle_SQL中rowid与rownum的使用.doc`直接相关外,其他文件如`ssi2配置整合...

    对于 Oracle 的 rownum 问题

    可如果用 select rownum,c1 from t1 where rownum > 10 (如果写下这样的查询语句,这时候在您的头脑中应该是想得到表中后面10条记录),你就会发现,显示出来的结果要让您失望了,也许您还会怀疑是不谁删了一些记录,...

    oracle rownum 学习

    Oracle ROWNUM是Oracle系统顺序分配的行号,用于限制查询返回的总行数。ROWNUM是一个伪字段,不能以任何表的名称作为前缀。下面是对ROWNUM的详细讲解: 一、ROWNUM的基本用法 ROWNUM是一个伪字段,用于限制查询...

    rowid与rownum区别

    ORACLE 中ROWNUM用法总结!数据库管理员及程序开发员必看。

    oracle-rownum用法

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

    oracle的分页查询

    本文将讲解 Oracle 中的分页查询,包括使用 ROWNUM 伪列和 ORDER BY 子句对查询结果进行排序和分页。 一、使用 ROWNUM 伪列实现分页查询 在 Oracle 中,ROWNUP 伪列是一个特殊的列,可以用来实现分页查询。例如,...

    rowid与rownumber

    rowid 和 rownum 是 Oracle 数据库中的两个重要概念,对于数据库开发人员来说非常重要。下面我们将详细介绍 rowid 和 rownum 的概念、结构、应用场景等。 一、rowid 概念 rowid 是 Oracle 数据库中的一个虚列,...

    关于oracle的rownum

    3. 如果你想得到表中后面 10 条记录,可以使用嵌套语句,先生成 ROWNUM,然后对他进行查询。 例如,select * from (select rownum as rn,t1.* from a where ...) where rn > 10。 另外,rowid 与 rownum 虽然都...

    ORACLE数据库中ROWNUM用法详解

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

    oracle数据库伪列简单介绍

    ### Oracle数据库伪列简析:rownum与rowid的区别...综上所述,rownum和rowid在Oracle数据库中分别扮演着重要的角色,它们各自具有独特的特性和应用场景。合理利用这两种伪列可以帮助开发者更高效地管理数据库中的数据。

    Oracle数据库中ORDER BY排序和查询按IN条件的顺序输出

    在Oracle数据库中,排序操作是数据库查询中非常关键的一部分,...同时,理解`ROWNUM`和`ROWID`的区别对于优化查询性能和确保数据一致性至关重要。通过掌握这些知识,我们可以更好地设计和优化Oracle数据库的查询操作。

Global site tag (gtag.js) - Google Analytics