赛迪网 > IT技术 数据库 > 精彩更新
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

教你使用索引跳跃式扫描来提高查询速度

发布时间:2007.08.24 01:54     来源:赛迪网    作者:puyu

索引跳跃式扫描(index skip scan)是Oracle9i的一个新的执行特性,尤其适用于使用连接索引和访问多值索引的Oracle查询。让我们看以下的范例。请注意到以下代码包含着连接索引:

create index

  sex_emp_id

  on

  emp (sex, emp_id)

  ;

  

在Oracle9i版本之前,当SQL查询中包含性别和emp_id时,或者查询指定性别行的时候才可以使用这一索引。下面的查询不能够使用连接索引:

select

  emp_id

  from

  emp

  where

  emp_id = 123;

  

Oracle9i的索引跳跃式扫描执行规则允许使用连接索引,即使SQL查询中不指定性别。这一特性使得无需在emp_id行中提供第二个索引。Oracle承认索引跳跃式扫描没有直接索引查询速度快,但可以这样说,相比于整个表扫描(table scan),索引跳跃式扫描的速度要快得多。

当Oracle没有指明索引跳跃式扫描的内部内容时,我们可以从它的执行规则中判断出,Oracle在内部上生成了多个查询,这样就满足带有多个子查询的查询。

  SELECT STATEMENT Optimizer=CHOOSE (Cost=6 Card=1 Bytes=5)   0 SORT (AGGREGATE)   1 INDEX (SKIP SCAN) OF 'SEX_EMP_ID' (NON-UNIQUE)   在内部里,Oracle生成了两个查询,并连接结果的ROWID表。   selectemp_name from emp_where sex = 'F' and emp_id = 123   UNION   select emp_name from emp_where sex = 'M' and emp_id = 123;

对于高顺序键(high order key)中的独特值数目,Oracle的索引跳跃式扫描性能将会降低。如果主列有50个值,Oracle要发出50条查询才能找回结果。

索引跳跃式扫描只适用于硬盘空间和存储空间相当紧缺的情况。

(责任编辑:卢兆林)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 识别真正的索引 (08-15) · 如何识别真正的索引并可以自动创建索引 (08-14)
· 使用索引查询的七个通用原则 (08-13) · 解析:合理使用索引查询的七个通用原则 (08-12)
· 清除Oracle无用的索引改善DML (08-09) · 停止Windows 2000的部分服务加快系统速度 (07-27)
· 针对WEB应用威胁 将安全与速度整合一体 (06-29) · 怎样才能最大限度地提升网络速度与性能 (06-05)
· 七大方法 让你最大限度地提升网络速度 (05-29) · Oracle中建立索引并强制优化器使用 (03-07)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管