MySQL索引的分类、何时使用、何时不使用、何时失效?


MySQL每次查询只使用一个索引。与其说是“数据库查询只能用到一个索引”,倒不如说,和全表扫描比起来,去分析两个索引B+树更加耗费时间。所以where A=a and B=b这种查询使用(A,B)的组合索引最佳,B+树根据(A,B)来排序。

  1. 主键,unique字段;

  2. 和其他表做连接的字段需要加索引;

  3. 在where里使用>,≥,=,<,≤,is null和between等字段;

  4. 使用不以通配符开始的like,where A like ‘China%’;

  5. 聚集函数MIN(),MAX()中的字段;

  6. order by和group by字段;

3、何时不使用索引


  1. 表记录太少;

  2. 数据重复且分布平均的字段(只有很少数据值的列);

  3. 经常插入、删除、修改的表要减少索引;

  4. text,image等类型不应该建立索引,这些列的数据量大(假如text前10个字符唯一,也可以对text前10个字符建立索引);

  5. MySQL能估计出全表扫描比使用索引更快时,不使用索引;

4、索引何时失效


  1. 组合索引未使用最左前缀,例如组合索引(A,B),where B=b不会使用索引;

  2. like未使用最左前缀,where A like ‘%China’;

  3. 搜索一个索引而在另一个索引上做order by,where A=a order by B,只使用A上的索引,因为查询只使用一个索引 ;

  4. or会使索引失效。如果查询字段相同,也可以使用索引。例如where A=a1 or A=a2(生效),where A=a or B=b(失效)

  5. 如果列类型是字符串,要使用引号。例如where A=‘China’,否则索引失效(会进行类型转换);

  6. 在索引列上的操作,函数(upper()等)、or、!=(<>)、not in等;

5、explain语句


type字段为All,未使用索引;为ref,使用索引

  • ALL: 全表扫描

  • index: 索引全扫描

  • range: 索引范围扫描,常用语<,<=,>=,between等操作

  • ref: 使用非唯一索引扫描或唯一索引前缀扫描,返回单条记录,常出现在关联查询中

  • eq_ref: 类似ref,区别在于使用的是唯一索引,使用主键的关联查询

  • const/system: 单条记录,系统会把匹配行中的其他列作为常数处理,如主键或唯一索引查询

  • null: MySQL不访问任何表或索引,直接返回结果

还有key字段表示用到的索引,没有用到为null

推荐文章

更多项目源码

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!**

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>