
MySQL中为避免索引失效所需注意的问题
类似于书籍的目录索引,提高数据检索的效率,降低数据库的IO成本。
通过索引列对数据进行排序,降低数据排序的成本,降低CPU的消耗。
实际上索引也是一张表,该表中保存了主键与索引字段,并指向实体类的记录,所以索引列也是要占用空间 的。
虽然索引大大提高了查询效率,同时却也降低更新表的速度,如对表进行INSERT、UPDATE、DELETE。因为 更新表时,MySQL 不仅要保存数据,还要保存一下索引文件每次更新添加了索引列的字段,都会调整因为更新所带来的键值变化后的索引信
全值匹配 ,对索引中所有列都指定具体值。该情况下,索引生效,执行效率高。
如果索引了多列,要遵守左前缀法则。指的是查询从索引的左前列开始,并且不跳过索引中的列。
创建索引的方式:
Ⅰ、匹配最左前缀法则,走索引
Ⅱ、违背最左前缀法则,索引失效
Ⅲ、如果符合最左前缀法则,但是出现跳跃某一列,则只有左列索引生效
如下,范围查询之后的address没有使用索引
由于,在查询时,没有对字符串加单引号,MySQL的查询优化器,会自动的进行类型转换,造成索引失效。
示例,name 字段是索引列 , 而 createtime 不是索引列,中间是 or 进行连接是不走索引的 :
如果仅仅是尾部模糊匹配,索引不会失效。如果是头部模糊匹配,索引失效。
解决方案:覆盖索引
这里索引失效的原因其实就是上面的第九条
2020-9-6