脑图






详细介绍
索引介绍
| MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。 |
| 打个比方,如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车。 |
| 拿汉语字典的目录页(索引)打比方,我们可以按拼音、笔画、偏旁部首等排序的目录(索引)快速查找到需要的字。 |
| 索引分单列索引和组合索引。单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。组合索引,即一个索引包含多个列。 |
| 创建索引时,你需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。 |
| 实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。 |
| 上面都在说使用索引的好处,但过多的使用索引将会造成滥用。因此索引也会有它的缺点:虽然索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。 |
| 建立索引会占用磁盘空间的索引文件。 |
组合索引
| 例如组合索引(a,b,c),组合索引的生效原则是 |
| 从前往后依次使用生效,如果中间某个索引没有使用,那么断点前面的索引部分起作用,断点后面的索引没有起作用; |
| 比如 |
| where a=3 and b=45 and c=5 .... 这种三个索引顺序使用中间没有断点,全部发挥作用; |
| where a=3 and c=5... 这种情况下b就是断点,a发挥了效果,c没有效果 |
| where b=3 and c=4... 这种情况下a就是断点,在a后面的索引都没有发挥作用,这种写法联合索引没有发挥任何效果; |
| where b=45 and a=3 and c=5 .... 这个跟第一个一样,全部发挥作用,abc只要用上了就行,跟写的顺序无关 |
| 组合索引使用判断: |
| (0) select * from mytable where a=3 and b=5 and c=4; |
| abc三个索引都在where条件里面用到了,而且都发挥了作用 |
| (1) select * from mytable where c=4 and b=6 and a=3; |
| 这条语句列出来只想说明 mysql没有那么笨,where里面的条件顺序在查询之前会被mysql自动优化,效果跟上一句一样 |
| (2) select * from mytable where a=3 and c=7; |
| a用到索引,b没有用,所以c是没有用到索引效果的 |
| (3) select * from mytable where a=3 and b>7 and c=3;(范围值就算是断点) |
| a用到了,b也用到了,c没有用到,这个地方b是范围值,也算断点,只不过自身用到了索引 |
| (4) select * from mytable where b=3 and c=4; |
| 因为a索引没有使用,所以这里 bc都没有用上索引效果 |
| (5) select * from mytable where a>4 and b=7 and c=9; |
| a用到了 b没有使用,c没有使用 |
| (6) select * from mytable where a=3 order by b; |
| a用到了索引,b在结果排序中也用到了索引的效果,前面说了,a下面任意一段的b是排好序的 |
| (7) select * from mytable where a=3 order by c; |
| a用到了索引,但是这个地方c没有发挥排序效果,因为中间断点了,使用 explain 可以看到 filesort |
| (8) select * from mytable where b=3 order by a; |
| b没有用到索引,排序中a也没有发挥索引效果 |
推荐了解主题
- B+tree 原理
- 索引冲突解决
- 索引与存储引擎的关系
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具