根:分支的范围,范围块的地址

----- begin tree dump

branch: 0x1000c93 16780435 (0: nrow: 5, level: 1)

   leaf: 0x1000c94 16780436 (-1: nrow: 485 rrow: 485)

   leaf: 0x1000c95 16780437 (0: nrow: 479 rrow: 479)

   leaf: 0x1000c96 16780438 (1: nrow: 479 rrow: 479)

   leaf: 0x1000c97 16780439 (2: nrow: 479 rrow: 479)

   leaf: 0x1000c98 16780440 (3: nrow: 78 rrow: 78)

----- end tree dump

SQL> select dbms_utility.data_block_address_file('16780435') FILE_ID,

       dbms_utility.data_block_address_block('16780435') BLOCK_ID

  from dual;  2    3

FILE_ID   BLOCK_ID

---------- ----------

  4  3219

Btree 索引的 root block总是segment header+1,所以我查询该索引的段头 

 

SQL>  select header_file,header_block from dba_segments where segment_name='IDX_TEST';

HEADER_FILE HEADER_BLOCK

----------- ------------

   4     3218

0x1000c93 16进制表示的DBA(data block address),

DBA 之后表示在同一层次的相对位置(root 从0开始,branch 以及leaf从 -1开始) 

nrow  表示块中包含了多少条目(包括delete的条目) 

rrow  表示块中包含的实际条目(不包括delete的条目) 

level 表示从该block到leaf的深度(leaf没有 level)

分支块之间没有联系

索引当中leaf 永远只有1层

为什么 叶子块 是双向链表?

索引默认升序排序

索引当中数据最小放最左边,最大放最右边

对于主键的索引,只增长的都是右边热。

索引的 range scan 究竟是 咋个扫描的???

范围扫描将会从根数据块开始到第一个包含符合特定条件的条目所在的叶子块来遍历索引结构。 

 

再从那一点开始,从索引条目中取出一个行编号然后取出相应的表数据块(通过索引行编号访问数据表) 

 

在第一行被取出来之后,之前的叶子索引块将再一次被访问并读取下一个索引条目来获取下一个行编号。 

 

这种索引叶子块之间的反复来回将会不断持续直到所有匹配的索引都被读出。 

 

因此,所需访问数据块的次数将包含索引中的分支块数(可以通过索引的blevel统计信息得出) 

加上符合条件的索引条目数乘以2. 

 

必须乘以2是因为每取出表中返回5行数据并且blevel为3,则总的需要访问的数据块次数将是 (5行 * 2) + 3=13

索引的 range scan 究竟是 咋个扫描的???

首先找到索引的root块

oracle 为啥能找到 索引的root??

因为root块总是segment header+1

找到root就会找到分支,找到分支就会找到叶子节点。

index rang scan的更多相关文章

  1. INDEX RANG SCAN无需回表的情况

    create table a3 as select * from dba_objects create index a3_idx1 on a3(owner); select owner from a3 ...

  2. index full scan/index fast full scan/index range scan

    **************************1************************************* 索引状态:          valid.      N/A .    ...

  3. Index Skip Scan in Oracle in 11g

    http://viralpatel.net/blogs/oracle-index-skip-scan/ in 11g the same sql use index skip scan but in 1 ...

  4. index unique scan 与index range scan等的区别

    存取Oracle当中扫描数据的方法(一) Oracle 是一个面向Internet计算环境的数据库.它是在数据库领域一直处于领先地位的甲骨文公司的产品.可以说Oracle关系数据库系统是目前世界上流行 ...

  5. Oracle分区表之分区范围扫描(PARTITION RANGE ITERATOR)与位图范围扫描(BITMAP INDEX RANGE SCAN)

    一.前言: 一开始分区表和位图索引怎么会挂钩呢?可能现实就是这么的不期而遇:比如说一张表的字段是年月日—‘yyyy-mm-dd’,重复率高吧,适合建位图索引吧,而且这张表数据量也不小,也适合转换成分区 ...

  6. Oracle 11G INDEX FULL SCAN 和 INDEX FAST FULL SCAN 对比分析

    SQL> drop table test; 表已删除. SQL> create table test as select * from dba_objects where 1!=1; 表已 ...

  7. 【每日一摩斯】-Index Skip Scan Feature (212391.1)

    INDEX Skip Scan,也就是索引快速扫描,一般是指谓词中不带复合索引第一列,但扫描索引块要快于扫描表的数据块,此时CBO会选择INDEX SS的方式. 官方讲的,这个概念也好理解,如果将复合 ...

  8. INDEX FAST FULL SCAN和INDEX FULL SCAN

    INDEX FULL SCAN 索引全扫描.单块读 .它扫描的结果是有序的,因为索引是有序的.它通常发生在 下面几种情况(注意:即使SQL满足以下情况 不一定会走索引全扫描) 1. SQL语句有ord ...

  9. Index Full Scan vs Index Fast Full Scan-1103

    [Oracle] Index Full Scan vs Index Fast Full Scan作者:汪海 (Wanghai) 日期:14-Aug-2005 出处:http://spaces.msn. ...

随机推荐

  1. systemtap分析软raid io拆分问题

    http://www.sysnote.org/2014/05/01/systemtap-analysis-mdraid-io/

  2. [转] json in javascript

    JavaScript is a general purpose programming language that was introduced as the page scripting langu ...

  3. 【Android】退出运行了多个Activity的应用

    日常开发APP的时候,绝大多数情况下会有多个Activity,而finish()方法只能结束掉一个Activity,那么,我们可以通过什么方法去退出整个Application呢? 根据各大牛的经验,有 ...

  4. native跟volatile

    native是告知编译器 该方法是其他语言实现的 比如C 呵呵 private native void CoutSea();没有方法实现部分的 volatile是Java语言的关键字,用在变量的声明中 ...

  5. C#生成缩略图不清晰模糊问题的解决方案!

    之前网上找了个生成缩略图的代码,改了改直接用了.问题来了,等比例缩略图时总是发现左边.上边的边线大概有一像素的白边,领导不乐意了,那咱就改吧.图片放大了才发现,那个好像是渐变的颜色,晕,这样的功能领导 ...

  6. java判断字符串是否为空的方法总结

    http://blog.csdn.net/qq799499343/article/details/8492672 以下是java 判断字符串是否为空的四种方法: 方法一: 最多人使用的一个方法, 直观 ...

  7. copssh加bitvise

    只是简单记录下自己在成功使用的方案: 目的:为了突破公司对网站和qq的限制 具备的条件:一台云服务器.Copssh_4.1.0.bitvise ssh client 4.62.公司电脑客户端 一.首先 ...

  8. ORACLE多表关联UPDATE 语句

    转载至:http://blog.itpub.net/29378313/viewspace-1064069/ 为了方便起见,建立了以下简单模型,和构造了部分测试数据:在某个业务受理子系统BSS中, SQ ...

  9. SQL语句之二建表

    use Test --进入需要建表的数据库if exists(select * from sysobjects where name='MyTable')--表是否已经存在drop table MyT ...

  10. TOM大师脚本01-查找未建索引的外键

    [oracle@Oracle11g 2016]$ cat 022201.sql column columns format a30 word_wrappedcolumn tablename forma ...