设为首页 加入收藏

TOP

oracle性能优化操作八:利用HINT强制指定索引
2015-07-24 11:45:46 来源: 作者: 【 】 浏览:2
Tags:oracle 性能 优化 操作 利用 HINT 强制 指定 索引

在ORACLE优化器无法用上合理索引的情况下,利用HINT强制指定索引。

继续“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忽略掉。

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Oracle11gR2数据库flashback功能-.. 下一篇unix&linuxoralce用户内存使..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·C++ 语言社区-CSDN社 (2025-12-24 17:48:24)
·CSDN问答专区社区-CS (2025-12-24 17:48:22)
·C++中`a = b = c`与` (2025-12-24 17:48:19)
·C语言结构体怎么直接 (2025-12-24 17:19:44)
·为什么指针作为c语言 (2025-12-24 17:19:41)