转载http://blog.sina.com.cn/s/blog_4d9acd450100nt12.html
1.隐式转换导致索引失效.这一点应当引起重视.也是开发中经常会犯的错误.
由于表的字段tu_mdn定义为varchar2(20),但在查询时把该字段作为number类型以where条件传给Oracle,这样会导致索引失效.
错误的例子:select * from test where tu_mdn=13333333333;
正确的例子:select * from test where tu_mdn='13333333333';
2. 对索引列进行运算导致索引失效,我所指的对索引列进行运算包括(+,-,*,/,! 等)
错误的例子:select * from test where id-1=9;
正确的例子:select * from test where id=10;
3. 使用Oracle内部函数导致索引失效.对于这样情况应当创建基于函数的索引.
错误的例子:select * from test where round(id)=10; 说明,此时id的索引已经不起作用了
正确的例子:首先建立函数索引,create index test_id_fbi_idx on test(round(id));然后 select * from test where round(id)=10; 这时函数索引起作用了
4. 以下使用会使索引失效,应避免使用;
a. 使用 <> 、not in 、not exist、!=
b. like "%_" 百分号在前(可采用在建立索引时用reverse(columnName)这种方法处理)
c. 单独引用复合索引里非第一位置的索引列.应总是使用索引的第一个列,如果索引是建立在多个列上, 只有在它的第一个列被where子句引用时,优化器才会选择使用该索引。
d. 字符型字段为数字时在where条件里不添加引号.
e. 当变量采用的是times变量,而表的字段采用的是date变量时.或相反情况。
5. 不要将空的变量值直接与比较运算符(符号)比较。
如果变量可能为空,应使用 IS NULL 或 IS NOT NULL 进行比较,或者使用 ISNULL 函数。
6. 不要在 SQL 代码中使用双引号。
因为字符常量使用单引号。如果没有必要限定对象名称,可以使用(非 ANSI SQL 标准)括号将名称括起来。
7. 将索引所在表空间和数据所在表空间分别设于不同的磁盘chunk上,有助于提高索引查询的效率。
8. Oracle默认使用的基于代价的SQL优化器(CBO)非常依赖于统计信息,一旦统计信息不正常,会导致数据库查询时不使用索引或使用错误的索引。
一般来说,Oracle的自动任务里面会包含更新统计信息的语句,但如果表数据发生了比较大的变化(超过20%),可以考虑立即手动更新统计信息,例如:analyze table abc compute statistics,但注意,更新统计信息比较耗费系统资源,建议在系统空闲时执行。
9. Oracle在进行一次查询时,一般对一个表只会使用一个索引.
因此,有时候过多的索引可能导致Oracle使用错误的索引,降低查询效率。例如某表有索引1(Policyno)和索引2(classcode),如果查询条件为 policyno = ‘xx’ and classcode = ‘xx’,则系统有可能会使用索引2,相较于使用索引1,查询效率明显降低。
10. 优先且尽可能使用分区索引。
----------------------------------
分享到:
相关推荐
10. **分组和排序(GROUP BY 和 ORDER BY)**:如果分组或排序的列没有索引,MySQL可能需要进行临时排序,导致索引失效。 11. **索引覆盖不完全**:如果查询只选择了索引中的部分列,而其他列需要回表获取,MySQL...
然而,在实际的应用过程中,由于多种原因可能会导致索引失效,从而影响系统的性能。本文将详细介绍Oracle索引失效的一些常见原因,并提供相应的解决策略。 #### 1. 使用函数或表达式对列进行操作 当在WHERE子句中...
总结来说,虽然使用`OR`操作符的SQL语句可能在某些情况下导致索引失效,但在MySQL 5.0之后,通过`index_merge`特性,我们可以有效地利用多个索引。然而,这并不意味着所有包含`OR`的查询都能自动优化,数据库管理员...
= 或 )、大于(>)、小于(<)、大于等于(>=)、小于等于()等不等式操作符可能导致索引失效。特别是,当比较值为NULL时,MySQL通常不会使用索引。 **3. NULL值的影响** 如果列允许NULL值,那么索引可能不会包含...
通过对以上11种索引失效情况的学习,我们可以更好地理解MySQL数据库如何处理索引以及如何避免索引失效的问题。在实际应用中,我们需要结合具体的业务场景来优化索引的设计与使用,以确保数据库的高效运行。同时,...
此外,还有一些其他情况会导致索引失效: 1. `OR`条件的存在。如果查询语句中包含`OR`,即使部分条件有索引,MySQL也可能不会使用这些索引。除非为每个`OR`子句中的列都创建单独的索引。 2. 多列索引的非第一部分。...
第三,`LIKE`查询中的模糊匹配,特别是以`%`开头的模式,会导致索引失效。例如,`WHERE column LIKE '%value%'`。在这种情况下,MySQL无法直接通过索引定位数据,因为`%`前缀意味着从任何位置开始匹配,所以会进行全...
然而,尽管索引在多数情况下能提升查询效率,但存在一些情况可能导致索引失效或无法充分利用: 1. **OR条件**:当查询条件中包含多个字段使用OR操作符时,即使其中某些字段有索引,MySQL也可能不会使用这些索引。...
然而,当涉及使用变量进行查询时,有时可能会遇到索引失效的问题。这个问题在一个名为"SF_Cp_Detail"的表中表现得尤为明显,该表拥有一个针对字段`Mac2`的唯一非聚集索引`IX_SF_CP_Detail_MAC2`。这个索引是为了确保...
查询条件包含or,可能导致索引失效 如何字段类型是字符串,where时一定用引号括起来,否则索引失效 like通配符可能导致索引失效。 联合索引,查询时的条件列不是联合索引中的第一个列,索引失效。...
这种情况下,即使查询条件与索引列完全一致,也仍然可能因为数据类型不匹配而导致索引失效。 **示例**:假设表中有一列为`char(10)`类型,而索引建立在`int`类型上,当执行如下查询时: ```sql SELECT * FROM ...
其次,统计信息的过期或不准确也会导致索引失效。Oracle依赖于统计信息来决定最佳执行计划,如果这些信息不准确,优化器可能无法正确评估索引的价值。定期执行`ANALYZE TABLE`命令更新统计信息是必要的。 另外,...
MySQL中的索引是提高查询效率的关键工具,但不恰当的SQL使用可能导致索引失效,从而影响性能。以下是一些常见的索引失效场景及其规避方法: 1. **OR条件的使用**: 当`WHERE`子句中包含`OR`操作时,如果两边的查询...
没有特殊说明,测试环境均为MySQL8.0,早期版本可能会有更多情况导致索引失效。8.0失效的情况,早期版本也失效;8.0不失效的情况,早期版本可能失效。 所有测试默认不考虑表为空的情况,特殊情况文中会有说明。 本文...
索引并不是时时都会生效的,比如以下几种情况,将导致索引失效: 1.如果条件中有or,即使其中有条件带索引也不会使用(这也是为什么尽量少用or的原因) 注意:要想使用or,又想让索引生效,只能将or条件中的每个...
4. **IS NULL 和 IS NOT NULL**:在WHERE子句中直接使用`IS NULL`或`IS NOT NULL`也可能导致索引失效。可以使用`NVL`函数结合函数索引来避免这个问题。 示例: ```sql SELECT * FROM A WHERE NVL(B, C) = C ```...