暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle性能优化:SQL优化之十五——函数索引

oracleEDU 2017-11-10
424

接上一节内容,本节介绍函数索引。使用Oracle函数索引,无疑是提高查询效率的有效方法之一。下面就详细介绍Oracle函数索引的使用方法。

为了避免由于在条件匹配时引入函数,导致执行计划不再使用索引,oracle提供了基于函数的索引,进而解决前述问题,提高访问效率。

需要注意的是:
在使用函数索引时,SQL语句中的条件表达式必须与函数索引的表达式完全一致,空格、关键字大小写都不可以忽略。如果不完全一致,则无法利用函数索引。

任何对列的操作都可能导致全表扫描

例:

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

这种查询又经常使用,我们可以创建一个带有substr函数的基于Oracle函数索引:

SQL> create index emp_ename_substr on emp (substr(ename,1,2));

这样在执行上面的查询语句时,这个基于函数的索引将排上用场,执行计划将是(INDEX RANGE SCAN)

执行计划:

如果执行下面的查询:

SQL> select * from emp where substr(ename,1,1)='S';

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

查看验证建立的函数索引

SQL> select a.INDEX_NAME INDEX_NAME,b.INDEX_TYPE INDEX_TYPE,a.TABLE_NAME TABLE_NAME,COLUMN_NAME,STATUS from user_ind_columns a,user_indexes b where a.INDEX_NAME=b.INDEX_NAME and a.table_name='EMP';

由于此索引是基于函数建立的,因此columns一列无法显示真正的列名,可以通过user_ind_expressions视图查看.

SQL> select * from user_ind_expressions where INDEX_NAME='EMP_ENAME_SUBSTR';

常用的Oracle索引视图

dba_indexes

user_indexes

dba_ind_columns

user_indexes

dba_expressions

user_expressions

其中:

dba_indexes与user_indexes视图,主要涵盖了索引的参数、状态以及关联的表信息,但不包含具体的列信息。

dba_ind_columns与user_ind_columns视图,主要涉及具体的索引列的信息。

dba_expressions与user_expressions视图,主要针对函数索引,可以查看具体的函数信息。

最后修改时间:2021-04-28 20:26:52
文章转载自oracleEDU,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论