如果表的数据量非常小,则MySQL可能不会使用索引,因为它认为全表扫描的代价更小。
当or左右查询字段只有一个是索引,该索引失效,只有当or左右查询字段均为索引时,才会生效
如果在索引列上执行类型转换,MySQL将无法使用索引来加速查询。
例如: select * from user where SUBSTR(height,1,2)=17;
例如: select * from user where id=height
如果把两个单独建了索引的列,用来做列对比时索引会失效。
如果表中某些值的出现频率非常高,那么MySQL可能会认为使用全表扫描代价更小,而不使用索引。
如果索引列的长度过长,MySQL将会使用更多的内存来存储索引,可能会影响性能。
如果索引列上存在重复值,MySQL将无法使用索引来加速查询。
不等于操作符是永远不会用到索引的,因此对它的处理只会产生全表扫描。