`
cry615
  • 浏览: 153537 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

oralce 的rownum 和rowid 学习

 
阅读更多

1.概念

  rowid和rownum都是伪列实际上这一列本身在数据字典中并不存在,在查询结果输出时它被构造出来的);

 

 1)rownum是基于查询结果的顺序标记,而且是逐次递加的,换句话说就是只要有rownum=1的记录,才可能有rownum=2的记录

 

 2)rowid是用于定位数据库中一条记录的一个相对唯一地址值。通常情况下,该值在该行数据插入到数据库表时即被确定且唯一。而对于聚簇表,由于聚簇特性,不同表上的记录由于存储在相同的簇上,因此会拥有相同的ROWID。数据库的大多数操作都是通过ROWID来完成的,而且使用ROWID来进行单记录定位速度是最快的。

 

   有受限的(orace8g以前)和 扩展的(oracle8g之后)两种形式,

   受限的rowid:

      文件编号(10bit) + 块编号(22bit) + 行编号(16bit) ,6个字节的存储空间

   扩展的rowid:

    数据对象编号(32bit) + 文件编号(10bit) + 块编号(22bit) + 行编号(16bit) ,10个字节的存储空间

 

   rowid是base64编码的,用A~Z a~z 0~9 + /共64个字符表示。A表示0,B表示1,……,a表示26,……,0表示52,……,+表示62,/表示63可以将其看做一个64进制的数。

   扩展的rowid也完全兼容受限的rowid   

   

  对rowid分析比较好的一些链接

    http://space.itpub.net/?uid-25744374-action-viewspace-itemid-729897

    http://www.cuug.com/xueyuanzhuanqu/jishuwenzhang/201110/jishuwenzhang-1147.html

2.实战

  1)rownum在分页,查询中用到较多

        where之后也只能rownum=1或<=n

  2)rowid 在删除重复记录时

    DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID)FROM EMP X WHERE X.EMP_NO = E.EMP_NO) ,而且比较高效;通过rowid快速定位到某记录,。。。

      也可以通过dbms_rowid这个包得到rowid的详细信息;

       还有rowid的一些函数ROWIDTOCHARROWIDTONCHAR,CHARTOROWID结合实际使用

 

        感受:之前对rowid有过了解,当并未深入;遇到时也只是以解决实际问题为主,但发现那并不是一个好的做法,而且之后对它也只是个懵懂的感觉,查一些资料当时会理解但还是会忘。感觉还是写下来比较好,也是个熟悉,总结的过程。实际的工作开发中并没有这样及时总结和学习的一种习惯,渐渐发现这并非明智之举,一些东西总得沉淀一下,要不永远不是自己的。

        上面一点小感,希望跟大家有所共鸣。

 

 

 

 

分享到:
评论

相关推荐

    Oracle学习笔记(rownum和rowid)

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

    在oracle中灵活使用Rownum和rowId

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

    oracle rownum 学习

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

    对于 Oracle 的 rownum 问题

    对于 Oracle 的 rownum 问题,很多资料都说不支持&gt;,&gt;=,=,between...and,只能用以上符号(&lt;、、!=),并非说用&gt;,&gt;=,=,between..and 时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来...

    oracle_SQL中rowid与rownum的使用

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

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

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

    oracle_SQL中ROWID与ROWNUM的使用

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

    oracle_SQL-rowid--rownum.zip_oracle

    在Oracle SQL中,`ROWID`和`ROWNUM`是两个非常重要的概念,它们在数据库查询和操作中扮演着关键角色。本篇文章将详细解析这两个概念及其应用。 **ROWID** `ROWID`是Oracle数据库中一个特殊的伪列,它为每一行数据...

    关于oracle的rownum

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

    rowid与rownum区别

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

    oracle-rownum用法

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

    rowid与rownumber

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

    Oracle DBA性能优化实践

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

    oracle数据库伪列简单介绍

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

    ORACLE数据库中ROWNUM用法详解

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

    Oracle 11g数据库学习笔记三

    本篇学习笔记主要讲解了Oracle 11g数据库中的数据伪列,包括ROWNUM和ROWID两种伪列的使用方法和应用场景。同时,也讨论了如何使用这些伪列来实现数据的分页功能和删除重复记录。 一、ROWNUM伪列 ROWNUM伪列是...

Global site tag (gtag.js) - Google Analytics