`
wayJava
  • 浏览: 29565 次
  • 性别: Icon_minigender_1
  • 来自: 福建
最近访客 更多访客>>
社区版块
存档分类
最新评论

导致索引失效的一些情况

阅读更多

转载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)和索引2classcode),如果查询条件为 policyno = xx and classcode = xx,则系统有可能会使用索引2,相较于使用索引1,查询效率明显降低。
    10. 优先且尽可能使用分区索引。
----------------------------------
分享到:
评论

相关推荐

    导致MySQL索引失效的一些常见写法总结

    10. **分组和排序(GROUP BY 和 ORDER BY)**:如果分组或排序的列没有索引,MySQL可能需要进行临时排序,导致索引失效。 11. **索引覆盖不完全**:如果查询只选择了索引中的部分列,而其他列需要回表获取,MySQL...

    oracle索引失效的总结

    然而,在实际的应用过程中,由于多种原因可能会导致索引失效,从而影响系统的性能。本文将详细介绍Oracle索引失效的一些常见原因,并提供相应的解决策略。 #### 1. 使用函数或表达式对列进行操作 当在WHERE子句中...

    这种sql写法真的会导致索引失效吗

    总结来说,虽然使用`OR`操作符的SQL语句可能在某些情况下导致索引失效,但在MySQL 5.0之后,通过`index_merge`特性,我们可以有效地利用多个索引。然而,这并不意味着所有包含`OR`的查询都能自动优化,数据库管理员...

    MySQL数据库索引失效的10种场景.zip

    = 或 )、大于(&gt;)、小于(&lt;)、大于等于(&gt;=)、小于等于()等不等式操作符可能导致索引失效。特别是,当比较值为NULL时,MySQL通常不会使用索引。 **3. NULL值的影响** 如果列允许NULL值,那么索引可能不会包含...

    MySQL索引失效的11种情况.docx

    通过对以上11种索引失效情况的学习,我们可以更好地理解MySQL数据库如何处理索引以及如何避免索引失效的问题。在实际应用中,我们需要结合具体的业务场景来优化索引的设计与使用,以确保数据库的高效运行。同时,...

    MySQL索引失效的几种情况汇总

    此外,还有一些其他情况会导致索引失效: 1. `OR`条件的存在。如果查询语句中包含`OR`,即使部分条件有索引,MySQL也可能不会使用这些索引。除非为每个`OR`子句中的列都创建单独的索引。 2. 多列索引的非第一部分。...

    mysql索引失效的五种情况分析

    第三,`LIKE`查询中的模糊匹配,特别是以`%`开头的模式,会导致索引失效。例如,`WHERE column LIKE '%value%'`。在这种情况下,MySQL无法直接通过索引定位数据,因为`%`前缀意味着从任何位置开始匹配,所以会进行全...

    数据库索引失效的几种情况

    然而,尽管索引在多数情况下能提升查询效率,但存在一些情况可能导致索引失效或无法充分利用: 1. **OR条件**:当查询条件中包含多个字段使用OR操作符时,即使其中某些字段有索引,MySQL也可能不会使用这些索引。...

    唯一非聚集索引变量传入时索引失效解决方案

    然而,当涉及使用变量进行查询时,有时可能会遇到索引失效的问题。这个问题在一个名为"SF_Cp_Detail"的表中表现得尤为明显,该表拥有一个针对字段`Mac2`的唯一非聚集索引`IX_SF_CP_Detail_MAC2`。这个索引是为了确保...

    【mysql面试题】100道MySQL数据库经典面试题解析

    查询条件包含or,可能导致索引失效   如何字段类型是字符串,where时一定用引号括起来,否则索引失效   like通配符可能导致索引失效。   联合索引,查询时的条件列不是联合索引中的第一个列,索引失效。...

    mysql索引失效.docx MySQL索引失效是指在查询执行过程中,数据库无法有效地使用索引来提高查询性能

    这种情况下,即使查询条件与索引列完全一致,也仍然可能因为数据类型不匹配而导致索引失效。 **示例**:假设表中有一列为`char(10)`类型,而索引建立在`int`类型上,当执行如下查询时: ```sql SELECT * FROM ...

    oracle数据库索引失效

    其次,统计信息的过期或不准确也会导致索引失效。Oracle依赖于统计信息来决定最佳执行计划,如果这些信息不准确,优化器可能无法正确评估索引的价值。定期执行`ANALYZE TABLE`命令更新统计信息是必要的。 另外,...

    MySQL中索引失效的常见场景与规避方法

    MySQL中的索引是提高查询效率的关键工具,但不恰当的SQL使用可能导致索引失效,从而影响性能。以下是一些常见的索引失效场景及其规避方法: 1. **OR条件的使用**: 当`WHERE`子句中包含`OR`操作时,如果两边的查询...

    Mysql5.7及8.0版本索引失效情况汇总

    没有特殊说明,测试环境均为MySQL8.0,早期版本可能会有更多情况导致索引失效。8.0失效的情况,早期版本也失效;8.0不失效的情况,早期版本可能失效。 所有测试默认不考虑表为空的情况,特殊情况文中会有说明。 本文...

    Mysql索引会失效的几种情况分析

    索引并不是时时都会生效的,比如以下几种情况,将导致索引失效:  1.如果条件中有or,即使其中有条件带索引也不会使用(这也是为什么尽量少用or的原因)  注意:要想使用or,又想让索引生效,只能将or条件中的每个...

    Oracle Index索引无效的原因与解决方法

    4. **IS NULL 和 IS NOT NULL**:在WHERE子句中直接使用`IS NULL`或`IS NOT NULL`也可能导致索引失效。可以使用`NVL`函数结合函数索引来避免这个问题。 示例: ```sql SELECT * FROM A WHERE NVL(B, C) = C ```...

Global site tag (gtag.js) - Google Analytics