欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

MySQL索引失效及使用索引的优缺点

程序员文章站 2022-04-10 08:43:26
...

本文所有实验基于MySQL5.7.21,实验将会用到Explain工具,不了解的同学可参考此文章:MySQL性能优化神器Explain详解

联合索引失效

先创建一个包含三个字段的联合索引,索引顺序如下:
MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 
由以下三张图的key_len字段我们可以得出三个索引的长度分别为:title长303,author长122,price长5.
MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 

联合索引使用时遵循最左匹配原则,如果不是从最左列开始时,整个索引失效,如果最左匹配则依次往右使用索引,直到碰到不匹配的地方之后生效之前匹配到的索引
MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 

范围查询会引起索引失效

为以上联合索引更换字段顺序为title,price,author。如果查询时包含范围查询则范围字段后面的字段失效
MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 

like查询失效

使用模糊查询时,%只有在最右方的时候才能生效

为title设置一个单独的索引

MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 

查询中含有不等于或者or则索引不生效

MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 

在索引列上做计算或函数导致失效

删除刚才创建的联合索引,为price字段创建一个单独的索引

MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 

字符串类型不加引号同样会失效

MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 

is null和 is not null

为title字段创建一个单独的索引
MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效 

注意事项

在进行索引使用测试时,可能会因为测试数据太少从而MySQL会认为查询语句走全表扫描比走索引更有效,所以会自动去除索引,为避免测试结果误导可使用如下方式强制MySQL使用索引

1
explain select * from book FORCE index(索引名称) where price=1+1;
使用索引的优点
  • 唯一索引或主键索引可以保证数据库表的唯一性
  • 可以提高查询效率和性能
  • 加速表连接的速度
  • 加快排序的效率
使用索引的缺点
  • 每次更新修改删除都需要维护索引、从而消耗性能
  • 索引文件会占用物理空间

推荐阅读

  1. SpringCloud学习系列汇总
  2. 为什么一线大厂面试必问redis,有啥好问的?
  3. 多线程面试必备基础知识汇总
  4. Java集合源码分析汇总-JDK1.8
  5. Linux常用命令速查-汇总篇
  6. JVM系列文章汇总

博客所有文章首发于公众号《Java学习录》转载请保留
扫码关注公众号即可领取2000GJava学习资源

MySQL索引失效及使用索引的优缺点
            
    
    博客分类: MySQL MySQL索引索引失效