1. 1) 没有查询条件,或者查询条件没有建立索引
  2. 2) 在查询条件上没有使用引导列
  3. 3) 查询的数量是大表的大部分,应该是30%以上。
  4. 4) 索引本身失效
  5. 5) 查询条件使用函数在索引列上,或者对索引列进行运算,运算包括(+,-,*,/,! 等)
  6.   错误的例子:select * from test where id-1=9; 正确的例子:select * from test where id=10;
  7. 6) 对小表查询
  8. 7) 提示不使用索引
  9. 8) 统计数据不真实
  10. 9) CBO计算走索引花费过大的情况。其实也包含了上面的情况,这里指的是表占有的block要比索引小。
  11. 10)隐式转换导致索引失效.这一点应当引起重视.也是开发中经常会犯的错误.
  12.   由于表的字段tu_mdn定义为varchar2(20),但在查询时把该字段作为number类型以where条件传给数据库,
  13.   这样会导致索引失效. 错误的例子:select * from test where tu_mdn=13333333333;
  14.   正确的例子:select * from test where tu_mdn='13333333333';
  15. 12) 1,<> 2,单独的>,<,(有时会用到,有时不会)
  16. 13) like "%_" 百分号在前.
  17. 14) 没做表分析.
  18. 15) 单独引用复合索引里非第一位置的索引列.
  19. 16) 字符型字段为数字时在where条件里不添加引号.
  20. 17) 对索引列进行运算.需要建立函数索引.
  21. 18) not in ,not exist.
  22. 19) 当变量采用的是times变量,而表的字段采用的是date变量时.或相反情况。
  23. 20) B-tree索引 is null不会走,is not null会走,位图索引 is null,is not null 都会走
  24. 21) 联合索引
      is not null 只要在建立的索引列(不分先后)都会走,
  25.   in null 必须要和建立索引第一列一起使用,当建立索引第一位置条件是is null 时,
  26.   其他建立索引的列可以是is null(但必须在所有列 都满足is null的时候),
  27.   或者=一个值; 当建立索引的第一位置是=一个值时,其他索引列可以是任何情况(包括is null =一个值),
  28. 以上两种情况索引都会走。其他情况不会走。
  29.  
  30. ---------
  31. 1MyISAM 存储引擎索引键长度总和不能超过1000 字节;
  32. 2BLOB TEXT 类型的列只能创建前缀索引;
  33. 3MySQL 目前不支持函数索引;
  34. 4、使用不等于(!= 或者<>)的时候MySQL 无法使用索引;
  35. 5、过滤字段使用了函数运算后(如abs(column)),MySQL 无法使用索引;
  36. 6Join 语句中Join 条件字段类型不一致的时候MySQL 无法使用索引;
  37. 7、使用LIKE 操作的时候如果条件以通配符开始( '%abc...'MySQL 无法使用索引;
  38. 8、使用非等值查询的时候MySQL 无法使用Hash 索引;
  39. 9、在我们使用索引的时候,需要注意上面的这些限制,尤其是要注意无法使用索引的情况,因为这很容易让我们因为疏忽而造成极大的性能隐患。

oracle 索引失效原因_汇总的更多相关文章

  1. oracle 索引失效原因及解决方法

    oracle 索引失效原因及解决方法 2010年11月26日 星期五 17:10 一.以下的方法会引起索引失效 ‍1,<>2,单独的>,<,(有时会用到,有时不会)3,like ...

  2. Oracle索引失效原因及解决方法

    一.Oracle索引失效的原因 1使用否定关键字 !=, <> ,not in,not exist select * fromdrama where id <> 1,Mysql ...

  3. oracle 索引失效原因

    转自  http://www.cnblogs.com/orientsun/archive/2012/07/05/2577351.html Oracle 索引的目标是避免全表扫描,提高查询效率,但有些时 ...

  4. ORACLE索引失效原因归纳[转]

    1.隐式转换导致索引失效.这一点应当引起重视.也是开发中经常会犯的错误.   由于表的字段tu_mdn定义为varchar2(20),但在查询时把该字段作为number类型以where条件传给Orac ...

  5. 能使 Oracle 索引失效的六大限制条件【转】

    . 引用自: http://www.cnblogs.com/orientsun/archive/2012/07/05/2577351.html  总结得非常到位 Oracle 索引的目标是避免全表扫描 ...

  6. 分享知识-快乐自己:能使 Oracle 索引失效的六大限制条件

    Oracle 索引的目标是避免全表扫描,提高查询效率,但有些时候却适得其反. 例如一张表中有上百万条数据,对某个字段加了索引,但是查询时性能并没有什么提高,这可能是 oracle 索引失效造成的.or ...

  7. 能使Oracle索引失效的七大限制条件

    Oracle 索引的目标是避免全表扫描,提高查询效率,但有些时候却适得其反. 例如一张表中有上百万条数据,对某个字段加了索引,但是查询时性能并没有什么提高,这可能是 oracle 索引失效造成的.or ...

  8. 【转】Oracle索引失效问题

    转自:http://www.cnblogs.com/millen/archive/2010/01/18/1650423.html 失效情况分析: <> 单独的>,<,(有时会用 ...

  9. Oracle索引失效问题:WHERE C1='' OR C2 IN(SubQuery),并发请求时出现大量latch: cache buffers chains等待

    问题描述: 项目反馈某功能响应时间很长,高峰期时系统整体响应很慢... 获取相应的AWR,问题确实比较严重,latch: cache buffers chains等待,因为这些会话SQL执行时间太长, ...

随机推荐

  1. JVM系列.JDK演进历史

    Java程序员为什么要了解虚拟机相关的知识 Java程序在设计之初就号称"一次编译,到处运行".Java之所以能做到"一次编译,处处运行"是因为Java虚拟机隐 ...

  2. 04.Django-视图与路由

    视图层 1. HTTP请求 HttpRequest对象 request.path #使用GET方法时,只会得到路径. request.get_full_path() #使用GET方法时,会得到包括路径 ...

  3. 透过 NestedScrollView 源码解析嵌套滑动原理

    NestedScrollView 是用于替代 ScrollView 来解决嵌套滑动过程中的滑动事件的冲突.作为开发者,你会发现很多地方会用到嵌套滑动的逻辑,比如下拉刷新页面,京东或者淘宝的各种商品页面 ...

  4. URL与URI的联系与区别

    作者:daixinye链接:https://www.zhihu.com/question/21950864/answer/154309494来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商 ...

  5. Go 语言入门教程:安装

    关注公众号:雨哥写 python. 学习 Go 语言,比较下和 python 的用法,争取对 python 有更深的理解. 为什么学 Go 我主要使用 python 语言,其他语言用得不多,希望学一门 ...

  6. Java实现 LeetCode 63 不同路径 II(二)

    63. 不同路径 II 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为"Start" ). 机器人每次只能向下或者向右移动一步.机器人试图达到网格的右下角(在 ...

  7. java实现第六届蓝桥杯分机号

    分机号 X老板脾气古怪,他们公司的电话分机号都是3位数,老板规定,所有号码必须是降序排列,且不能有重复的数位.比如: 751,520,321 都满足要求,而, 766,918,201 就不符合要求. ...

  8. java实现第六届蓝桥杯九数组分数

    九数组分数 九数组分数 1,2,3...9 这九个数字组成一个分数,其值恰好为1/3,如何组法? 下面的程序实现了该功能,请填写划线部分缺失的代码. public class A { public s ...

  9. JPA入门及深入

    一:ORM介绍 ORM(Object-Relational Mapping) 表示对象关系映射.在面向对象的软件开发中,通过ORM,就可以把对象映射到关系型数据库中.只要有一套程序能够做到建立对象与数 ...

  10. el-upload配合vue-cropper实现上传图片前裁剪

    需求背景 上传一个封面图,在上传之前需要对图片进行裁剪,上传裁剪之后的图片,类似微信的上传头像. 技术方案 上传肯定是用element的 el-upload 组件实现上传,非常方便,各种钩子函数. 裁 ...