oracle 性能优化操作八: 利用HINT强制指定索引
2015-01-06 09:00
666 查看
在ORACLE优化器无法用上合理索引的情况下,利用HINT强制指定索引。
继续“oracle 性能优化操作七”的例子,ORACLE缺省认定,表中列的值是在所有数据行中均匀分布的,
也就是说,在一百万数据量下,每种DisposalCourseFlag值各有12.5万数据行与之对应。
假设SQL搜索条件DisposalCourseFlag=2,利用DisposalCourseFlag列上的索引进行数据搜索效率,
往往不比全表扫描的高,ORACLE因此对索引“视而不见”,从而在查询路径的选择中,用其他字段上的索引甚至全表扫描。
根据我们上面的分析,数据值的分布很特殊,严重的不均匀。为了利用索引提高效率,此时,
一方面可以单独对该字段或该表用analyze语句进行分析,对该列搜集足够的统计数据,使ORACLE在查询选择性较高的值时能用上索引;
另一方面,可以利用HINT提示,在SELECT关键字后面,加上“/*+ INDEX(表名称,索引名称)*/”的方式,强制ORACLE优化器用上该索引。
比如:
上面的语句,实际执行中ORACLE用了全表扫描,HINT部分后,用到索引查询。如下:
请注意,这种方法会加大代码维护的难度,而且该字段上索引的名称被改变之后,必须要同步所有指定索引的HINT代码,
否则HINT提示将被ORACLE忽略掉。
继续“oracle 性能优化操作七”的例子,ORACLE缺省认定,表中列的值是在所有数据行中均匀分布的,
也就是说,在一百万数据量下,每种DisposalCourseFlag值各有12.5万数据行与之对应。
假设SQL搜索条件DisposalCourseFlag=2,利用DisposalCourseFlag列上的索引进行数据搜索效率,
往往不比全表扫描的高,ORACLE因此对索引“视而不见”,从而在查询路径的选择中,用其他字段上的索引甚至全表扫描。
根据我们上面的分析,数据值的分布很特殊,严重的不均匀。为了利用索引提高效率,此时,
一方面可以单独对该字段或该表用analyze语句进行分析,对该列搜集足够的统计数据,使ORACLE在查询选择性较高的值时能用上索引;
另一方面,可以利用HINT提示,在SELECT关键字后面,加上“/*+ INDEX(表名称,索引名称)*/”的方式,强制ORACLE优化器用上该索引。
比如:
select * from serviceinfo where DisposalCourseFlag=1 ;
上面的语句,实际执行中ORACLE用了全表扫描,HINT部分后,用到索引查询。如下:
select /*+ INDEX(SERVICEINFO,IX_S_DISPOSALCOURSEFLAG) */ * from serviceinfo where DisposalCourseFlag=1;
请注意,这种方法会加大代码维护的难度,而且该字段上索引的名称被改变之后,必须要同步所有指定索引的HINT代码,
否则HINT提示将被ORACLE忽略掉。
相关文章推荐
- oracle 性能优化操作八: 利用HINT强制指定索引
- oracle 性能优化操作七:索引提高数据分布不均匀时查询效率
- oracle 性能优化操作十四: 使用基于函数的索引
- Oracle的HINT可以强制指定SQL的执行计划,比如选择索引、表的连接顺序以及表的连接方式等等。(转)
- oracle 性能优化操作十五: 基于函数的索引要求等式匹配
- oracle 性能优化操作九: 屏蔽无用索引
- oracle 性能优化操作十七: 使用位图索引
- oracle 性能优化操作十八: 决定使用全表扫描还是使用索引
- oracle 性能优化操作九: 屏蔽无用索引
- oracle 性能优化操作十七: 使用位图索引
- oracle 性能优化操作十四: 使用基于函数的索引
- oracle 性能优化操作十八: 决定使用全表扫描还是使用索引
- oracle 性能优化操作七:索引提高数据分布不均匀时查询效率
- oracle 性能优化操作十六: 使用分区索引
- Oracle性能优化5-索引的不足
- 利用 Oracle EM 企业管理器 进行oracle SQL的优化(自动生成索引)
- oracle 用HINT方式强制索引
- Oracle性能优化4-索引
- 如何利用oracle第三方工具做数据库的性能优化
- Oracle查询语句中指定索引时优化器及指定索引不好使的处理方法