日期:2014-05-16  浏览次数:20510 次

唯一索引的索引键不保存rowid
       tom的oracle 9i&10g编程艺术中这样一句话:在一个非唯一索引中,oracle会把rowid作为一个额外列加到键上,使索引键为唯一; 先按索引键排序,再按rowid升序排序;在一个唯一索引中,不会再加rowid到索引键上。

       这个怎么理解呢?唯一索引的索引键不保存rowid,那怎么通过rowid查找数据表中某行的值呢。下面的内容是通过google搜索得来,来源:http://www.itpub.net/thread-1287023-1-1.html

下面是一个完整的用例,使用了数据DUMP技术。

SQL> conn / as sysdba
已连接。
SQL> create table t as select * from dba_objects;

表已创建。

SQL> create index t_idx on t(object_id);

索引已创建。

SQL> select t.header_file,t.header_block from dba_segments t
  2   where t.segment_name='T';

HEADER_FILE HEADER_BLOCK
----------- ------------
          1        58408

SQL> alter system dump datafile 1 block 58410;

系统已更改。

普通索引,内容如下:
row#0[8024] flag: ------, lock: 0, len=12
col 0; len 2; (2):  c1 03
col 1; len 6; (6):  00 40 e4 29 00 30

SQL> drop index t_idx;

索引已删除。

SQL> create unique index t_idx on t(object_id);

索引已创建。

SQL> select t.header_file,t.header_block from dba_segments t
  2   where t.segment_name='T_IDX';

HEADER_FILE HEADER_BLOCK
----------- ------------
          1        92136

SQL> alter system dump datafile 1 block 92138;

系统已更改。

SQL>

唯一索引,内容如下:
row#0[8025] flag: ------, lock: 0, len=11, data:(6):  00 40 e4 29 00 30
col 0; len 2; (2):  c1 03

可以看出,在非唯一索引中,Oracle会增加一列,用于存放对应rowid,即索引列的最后,并按照这个顺序排序。对于唯一索引,是放入data(6)中,即row header中。不论怎样,rowid还是会被存储的。