Oracle执行计划不走索引的原因总结

数据库 Oracle
本文我们主要对Oracle数据库执行计划不走索引的原因进行了总结,希望能够对您有所帮助。

Oracle数据库操作中,为什么有时一个表的某个字段明明有索引,当观察一些语的执行计划确不走索引呢?如何解决呢?本文我们主要就介绍这部分内容,接下来就让我们一起来了解一下。

不走索引大体有以下几个原因:

  • 你在Instance级别所用的是all_rows的方式
  • 你的表的统计信息(最可能的原因)
  • 你的表很小,上文提到过的,Oracle的优化器认为不值得走索引。

解决方法:

可以修改init.ora中的OPTIMIZER_MODE这个参数,把它改为Rule或Choose,重起数据库。也可以使用4中所提的Hint。

不走索引的其它原因:

1、建立组合索引,但查询谓词并未使用组合索引的***列,此处有一个INDEX SKIP SCAN概念。

2、在包含有null值的table列上建立索引,当时使用select count(*) from table时不会使用索引。

3、在索引列上使用函数时不会使用索引,如果一定要使用索引只能建立函数索引。

4、当被索引的列进行隐式的类型转换时不会使用索引。如:select * from t where indexed_column = 5,而indexed_column列建立索引但类型是字符型,这时Oracle会产生隐式的类型转换,转换后的语句类似于select * from t where to_number(indexed_column) = 5,此时不走索引的情况类似于case3。日期转换也有类似问题,如: select * from t where trunc(date_col) = trunc(sysdate)其中date_col为索引列,这样写不会走索引,可改写成select * from t where date_col >= trunc(sysdate) and date_col < trunc(sysdate+1),此查询会走索引。

5、并不是所有情况使用索引都会加快查询速度,full scan table 有时会更快,尤其是当查询的数据量占整个表的比重较大时,因为full scan table采用的是多块读,当Oracle优化器没有选择使用索引时不要立即强制使用,要充分证明使用索引确实查询更快时再使用强制索引。

6、<>

7、like’%dd’百分号在前。

关于Oracle执行计划不走索引的原因的相关知识的总结就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. Oracle 10g正则表达式REGEXP_LIKE简介
  2. Oracle 10g监听listener不能启动的解决方案总结
  3. Oracle 10g Shrink Table和Shrink Space使用详解
  4. Oracle 10g利用utlsampl.sql创建scott用户及样本数据
  5. Oracle 10g透明网关访问SQL Server 2000之配置监听
责任编辑:赵鹏 来源: 网易博客
相关推荐

2009-11-10 16:00:05

Oracle执行计划

2009-11-13 16:28:02

Oracle生成执行计

2009-11-18 17:05:47

捕获Oracle SQ

2019-11-28 08:31:21

Oracle数据库索引

2011-09-14 17:03:17

数据库执行计划解析

2010-10-27 15:26:42

Oracle执行计划

2021-12-13 22:15:29

SQLOracle共享池

2014-08-28 09:54:35

SQL Server

2017-09-22 11:01:00

Oracle数据库中直方图

2021-03-17 09:35:51

MySQL数据库explain

2015-04-22 14:17:45

SQL SERVERMSSQL SERVE缓冲区

2023-09-21 10:55:51

MysqlSQL语句

2021-05-28 10:46:36

MySQL执行计划

2020-09-15 08:44:57

MySQL慢日志SQL

2010-04-16 09:27:18

Ocacle执行计划

2022-08-15 15:09:26

SQL数据库MySQL

2022-08-08 08:03:44

MySQL数据库CBO

2011-08-18 09:19:19

SQL Server的SQL查询优化

2024-09-12 15:16:14

2022-02-15 07:36:21

SQLEXPLAIN数据库
点赞
收藏

51CTO技术栈公众号