ROWID和ROWNUM
Posted freakkkkk
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ROWID和ROWNUM相关的知识,希望对你有一定的参考价值。
rownum,rowid都叫伪列。 但是,rownum是逻辑上的编号,且其值总是从1开始,每行的rounum不是固定的。而rowid是“物理”编号。若数据库文件没有移动,则每行的 rowid一般是固定不变的。
因为ROWNUM是对结果集加的一个伪列,即先查到结果集之后再加上去的一个列 (强调:先要有结果集)。简单的说 rownum是对符合条件结果的序列号。它总是从1开始排起的。所以你选出的结果不可能没有1,而有其他大于1的值。
select rownum,c1 from t1 where rownum > 10; 结果什么都没有。
select rownum,c1 from t1 where rownum != 10;有前九条数据。
rowid与 rownum 虽都被称为伪列,但它们的存在方式是不一样的,rowid可以说是物理存在的,表示记录在表空间中的唯一位置ID,在DB中唯一。只要记录没被搬动过,rowid是不变的。rowid相对于表来说又像表中的一般列,所以以 rowid 为条件就不会有 rownum那些情况发生。
另外还要注意:rownum不能以任何基表的名称作为前缀。
以上是关于ROWID和ROWNUM的主要内容,如果未能解决你的问题,请参考以下文章
在Oracle中有个rowid和rownum,他们是一样的吗?有啥作用?大神求解!!!