oracle构建索引index后table的10046数据块读取测试
oracle构建索引index后table的10046数据块读取测试
[日期:2013-03-17]来源:linux社区 作者:wisdomone1[字体:]
测试目的
1,未创建索引前的表的扫描情况
1,扫描哪些数据块
2,数据块之间的关系
3,物理读
4,逻辑读
5,以上测试区分:全表扫描与部分表记录扫描
6,扫描数据块是采用单块读取还是多块读取还是先单块读后多块读取?
2,小结:
1,表扫描速度与数据块大小的关系
2,表扫描与并行度设置的关系
3,表扫描与db cache的关系
前文测试了全表扫描的数据块读取情况;如果对表建立了索引,,先读取索引,然后根据rowid再读取对应表记录的数据块
sql> create table t_detail(a int);
table created.
--插入10000条记录
sql> insert into t_detail select level from dual connect by level
10000 rows created.
sql> commit;
commit complete.
sql> create index idx_t_detail on t_detail(a);
index created.
--跟踪已建索引的查询
sql> alter system set events '10046 trace name context level 8';
system altered.
--因表数据量10000条,10046 trace对查询速度有一定影响
sql> select count(a) from t_detail where a=2000;
count(a)
----------
1
--关闭10046 trace
sql> alter system set events '10046 trace name context off';
system altered.
--仅摘录10046 trace重要内容
wait #2: nam='disk file operations i/o' ela= 886 fileoperation=2 fileno=10 filetype=2 obj#=69559 tim=31824399508 --先是一个等待事件
wait #2: nam='db file sequential read' ela= 20687 file#=10 block#=276483 blocks=1 obj#=69559 tim=31824420353 -单块读 file#=10 block#=276483 blocks=1 obj#=69559
wait #2: nam='db file sequential read' ela= 823 file#=10 block#=276488 blocks=1 obj#=69559 tim=31824421542 --继续单块读 file#=10 block#=276488 blocks=1 obj#=69559
fetch #2:c=0,e=23170,p=2,cr=2,cu=0,mis=0,r=1,dep=0,og=1,plh=1976055679,tim=31824421699 --然后提取数据了
stat #2 id=1 cnt=1 pid=0 pos=1 bj=0 p='sort aggregate (cr=2 pr=2 pw=0 time=0 us)'
stat #2 id=2 cnt=1 pid=1 pos=1 bj=69559 p='index range scan idx_t_detail (cr=2 pr=2 pw=0 time=0 us cost=1 size=13 card=1)'
--上述2个单块读的数据块是什么呢?表还是表所属索引的数据块
--可知上述trace中的对象不是表
sql> select owner,object_name,object_id from dba_objects where object_name='t_detail' and wner='scott';
owner object_name object_id
------------------------------ -------------------------------------------------------------------------------- ----------
scott t_detail 69558
--是不是索引呢,就是索引,所以单块读先是读取索引的数据块
sql> select owner,object_name,object_id from dba_objects where object_name='idx_t_detail' and wner='scott';
owner object_name object_id
------------------------------ -------------------------------------------------------------------------------- ----------
scott idx_t_detail 69559
--既然读取索引的数据块,哪这是索引的哪个位置的数据块呢
--index的段头块为276482
sql> select segment_name,header_file,header_block from dba_segments ds where ds.segment_name='idx_t_detail';
segment_name header_file header_block
-------------------------------------------------------------------------------- ----------- ------------
idx_t_detail 10 276482