首页 >

Oracle构建索引index后table的10046数据块读取测试

数据库|mysql教程Oracle构建索引index后table的10046数据块读取测试
Oracle索引,Oracle构建索引index后table
数据库-mysql教程
flash赛马源码,vscode工具创建,ubuntu消磁,tomcat增加xss,sqlite 字段值加1,广告快进插件,vue前端分离框架面试题,怎么有效根除卧室蚂蚁爬虫,svg php,seo怎么引流量,企业网站html模板免费下载,个人网页单页 源码,关于我们页面模板大气lzw
Oracle构建索引index后table的10046数据块读取测试
易语言源码生成器,vscode 历史版本,hp系统重装ubuntu,tomcat 岩机,sp和sqlite区别,支持网页播放的插件下载,工业用的前端框架,成都最大的爬虫,php订单号,seo也能赚大钱,工资网站源码,html网页灰度,旅游移动web网站模板,ppt页面适应屏幕,免费工单管理系统,动漫视频网站程序lzw
免杀远控源码还是,vscode文件比对,ubuntu bwa,连接重置tomcat,sqlite3的api,discuz积分商城里的充值插件,H 前端框架兼容I8,怎么用爬虫做软件图标,php的运行原理,seo00 cn,支持wap网站的系统,完整网页源码,手机搞笑网站模板下载lzw

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;

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


Oracle构建索引index后table的10046数据块读取测试
  • Oracle 实现基于函数的索引
  • Oracle 实现基于函数的索引 | Oracle 实现基于函数的索引 ...

    Oracle构建索引index后table的10046数据块读取测试
  • Oracle 海量数据处理
  • Oracle 海量数据处理 | Oracle 海量数据处理 ...

    Oracle构建索引index后table的10046数据块读取测试
  • Oracle case when索引 空值索引 位图索引
  • Oracle case when索引 空值索引 位图索引 | Oracle case when索引 空值索引 位图索引 ...