详解Oracle使用强制索引的方法与注意事项

本文主要给大家介绍了关于oracle使用强制索引的方法与注意事项,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。希望能帮助到大家。

oracle使用强制索引

在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。

以EMP表为例:

先在EMP表中建立唯一索引,如图。

详解Oracle使用强制索引的方法与注意事项

普通搜索:

SELECT * FROM EMP T

查看执行计划:

详解Oracle使用强制索引的方法与注意事项

可以看到,是走的全表扫描。

使用强制索引,在SELECT 后面加上/*…….*/ 中间加上索引的属性,代码如下:

SELECT /*+index(t pk_emp)*/* FROM EMP T     --强制索引,/*.....*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。  --如果表用了别名,注释里的表也要使用别名。

详解Oracle使用强制索引的方法与注意事项 

可以看到,这是走的是索引PK_EMP。

Oracle使用强制索引注意事项

最近对Oracle的SQL索引生效条件进行了验证,发现如下规律,记录如下:

1、索引生效与记录的条数相关

      a、2016-01-01~2016-11-30 数据量402518,索引生效

      b、2016-01-01~2016-12-30 数据量444844,索引不生效

SELECT    *   FROM    T_MAINS   WHERE    date &gt; TO_DATE (--备注今天是2017-01-23     '2016-01-01',     'yyyy-mm-dd hh24:mi:ss'    )   AND date <p></p><p><strong>2、T_MAINS已根据某个时间类型的字段进行分区,查询条件中如果能够精准定位到某个分区,可以提高SQL的执行效率</strong></p><p>相关推荐:</p><p><a href="http://www.php.cn/mysql-tutorials-377830.html" target="_self">mysql与oracle数据库停止与启动的批处理文件</a></p><p><a href="http://www.php.cn/mysql-tutorials-377830.html" target="_self">mysql与oracle数据库停止与启动的批处理文件</a></p><p><a href="http://www.php.cn/mysql-tutorials-377830.html" target="_self">mysql与oracle数据库停止与启动的批处理文件</a></p>

© 版权声明
THE END
喜欢就支持一下吧
点赞12 分享