`

oracle的rowid和rownum

阅读更多
    rowid与rownum都被称为伪列,但它们的存在方式是不一样的,rowid是在数据插入到数据库中时生成的,可以说是物理存在的,表示记录在表空间中的唯一位置ID,在DB中是唯一的,只要记录没被搬动过,rowid是不变的。rowid 相对于表来说又像表中的一般列,所以以 rowid 为条件就不会有rownum那些莫名其妙的结果出现。
    rownum是对结果集加的一个伪列,即先查到结果集之后再加上去的一个列 (强调:先要有结果集)。简单的说 rownum 是在sql执行时对符合条件结果的序列号。它总是从1开始排起的。所以你选出的结果不可能没有1,而有其他大于1的值。
    另外还要注意:rownum不能以任何基表的名称作为前缀。

    首先说说rowid,前面说只要记录没被搬动过,rowid就不会变,说明rowid在某些情况下是可以改变的,下面说说rowid的变动情况。
1、数据被删除后rowid可以被重用(摘自http://blog.itpub.net/22111412/viewspace-613623/,下面是按照博主的步骤本人在oracle11g下做的实验,与博主rowid被重用的情况不同,但可以重用)
   插入数据后查看rowid如下:

   删除id=7的记录,即删除AAAdrUAANAAJ9W3AAG这个rowid

  插入id为11、12,name为test的记录,查询rowid没有被重用
  插入id为13,name为空的记录,查询rowid被重用


    另外本人测试了插入id为11、12时name也为空的情况,也是等到插入第三条记录即id为13时才会重新用被删除的rowid;同样,后插入的三条记录name都为test或比长时也会在第三次重用rowid,可见oracle11g中rowid重用的规则与9i不同,本人环境限制无法导出dump,暂未找到规则

2、扩展数据字段长度,致使当前块容纳不下,需要移到新的块,此种情况下rowid并不会发生变化(摘自http://blog.itpub.net/22111412/viewspace-613500/,本人环境限制,无法导出dump,但是扩展字段内容后查询rowid不会发生变化)
3、通过online shark,rowid会改变(摘自http://blog.itpub.net/22111412/viewspace-613623/,本人在oracle11g环境测试)
4、alter table move会改变rowid(摘自http://blog.itpub.net/22111412/viewspace-613677/)



表1中的唯一(主键)是表2的外键时,使用truncate、delete删除报错问题:
1、表2中有数据,删除表1数据报错:唯一/主键被启用的外键引用
2、删除表2中的数据,使用truncate删除表1数据仍报上述错误,使用delete可以删除表1数据,why?
  • 大小: 26 KB
  • 大小: 23.8 KB
  • 大小: 29.7 KB
分享到:
评论

相关推荐

    rowid与rownum区别

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

    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学习笔记(rownum和rowid)

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

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

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

    oracle_SQL-rowid--rownum.zip_oracle

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

    对于 Oracle 的 rownum 问题

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

    rowid与rownumber

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

    在oracle中灵活使用Rownum和rowId

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

    基于Oracle RowID实现批量数据的分页下载.pdf

    总的来说,基于Oracle RowID的分页下载策略结合了`ROWNUM`、`StopKey`、逆向索引和多线程技术,旨在提供一种高效、稳定的方法来处理大规模数据的分批下载需求。这种策略不仅可以减轻数据库服务器的压力,还能确保...

    关于oracle的rownum

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

    oracle rownum 学习

    七、ROWNUM和排序 Oracle中的ROWNUM是在取数据的时候产生的序号,所以想对指定排序的数据去指定的ROWNUM行数据就必须注意了。例如: ```sql SELECT ROWNUM, ID, NAME FROM STUDENT ORDER BY NAME; ``` 可以看出,...

    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的伪列与分页

    Oracle提供了一些内置的伪列供用户使用,如`ROWID`和`ROWNUM`等,这些伪列可以帮助开发人员更方便地进行查询、排序等操作。 #### 二、ROWID与ROWNUM详解 **ROWID:** - **定义**:ROWID是Oracle中用于唯一标识表中...

    17.Oracle伪列1

    - 限制查询结果:rownum常用于LIMIT或TOP类似的功能,通过结合rownum和子查询,可以获取前N条记录。 - 分页查询:结合rownum和嵌套查询,可以实现分页效果,如选取特定范围的行。 - 排序和过滤:rownum可以在ORDER ...

Global site tag (gtag.js) - Google Analytics