接上一节内容,本节介绍函数索引。使用Oracle函数索引,无疑是提高查询效率的有效方法之一。下面就详细介绍Oracle函数索引的使用方法。
任何对列的操作都可能导致全表扫描
例:
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视图,主要针对函数索引,可以查看具体的函数信息。