日期:2014-05-16  浏览次数:20426 次

使用Oracle函数索引 提高查询效率

使用Oracle函数索引,无疑是提高查询效率的有效方法之一。下面就为您详细介绍Oracle函数索引的使用方法,希望对您能有所帮助。

谈到任何对列的操作都可能导致全表扫描,例如:

  1. select?*?from?emp?where?substr(ename,1,2)=’SM’;?

但是这种查询在客服系统又经常使用,我们可以创建一个带有substr函数的基于Oracle函数索引,

  1. create?index?emp_ename_substr?on?eemp?(?substr(ename,1,2)?);?

但是这种查询在客服系统又经常使用,我们可以创建一个带有substr函数的Oracle函数索引,

  1. create?index?emp_ename_substr?on?eemp?(?substr(ename,1,2)?);?

这样在执行上面的查询语句时,这个基于函数的索引将排上用场,执行计划将是(INDEX RANGE SCAN)。
上面的例子中,我们创建了基于函数的索引,但是如果执行下面的查询:

  1. select?*?from?emp?where?substr(ename,1,1)=’S’?

得到的执行计划将还是(TABLE ACCESS FULL),因为只有当数据列能够等式匹配时,基于函数的索引才能生效,这样对于这种索引的计划和维护的要求都很高。请注意,向表中添加索引是非常危险的操作,因为这将导致许多查询执行计划的变更。然而,如果我们使用基于函数的索引就不会产生这样的问题,因为Oracle只有在查询使用了匹配的内置函数时才会使用这种类型的索引。

?

【Oracle index】自定义函数索引使用及其注意点?

转:http://blog.chinaunix.net/uid-7655508-id-3708041.html