使用Oracle函数索引,无疑是提高查询效率的有效方法之一。下面就为您详细介绍Oracle函数索引的使用方法,希望对您能有所帮助。
谈到任何对列的操作都可能导致全表扫描,例如:
- select?*?from?emp?where?substr(ename,1,2)=’SM’;?
但是这种查询在客服系统又经常使用,我们可以创建一个带有substr函数的基于Oracle函数索引,
- create?index?emp_ename_substr?on?eemp?(?substr(ename,1,2)?);?
但是这种查询在客服系统又经常使用,我们可以创建一个带有substr函数的Oracle函数索引,
- create?index?emp_ename_substr?on?eemp?(?substr(ename,1,2)?);?
这样在执行上面的查询语句时,这个基于函数的索引将排上用场,执行计划将是(INDEX RANGE SCAN)。
上面的例子中,我们创建了基于函数的索引,但是如果执行下面的查询:
- select?*?from?emp?where?substr(ename,1,1)=’S’?
得到的执行计划将还是(TABLE ACCESS FULL),因为只有当数据列能够等式匹配时,基于函数的索引才能生效,这样对于这种索引的计划和维护的要求都很高。请注意,向表中添加索引是非常危险的操作,因为这将导致许多查询执行计划的变更。然而,如果我们使用基于函数的索引就不会产生这样的问题,因为Oracle只有在查询使用了匹配的内置函数时才会使用这种类型的索引。
?
【Oracle index】自定义函数索引使用及其注意点?
转:http://blog.chinaunix.net/uid-7655508-id-3708041.html