MySQL索引常见问题

专栏持续更新中:MySQL详解

问题1:用联合索引优化using filesort

首先,要给userid加索引(一般过滤条件的字段需要加索引),此时创建的是二级索引树,select *涉及回表。而且还有order by addtime,如果addtime没有建索引的话,explain分析时会出现using filesort,涉及addtime的文件排序!

我们可以添加联合索引(多列索引):userid+addtime

这样的话,在二级索引树上用userid过滤出来的数据中,addtime就已经是有序的了

addtime不建立索引,就有using filesort,数据的外排序。用userid选择出来的数据越多,耗费的排序性能差的越大

addTime有索引,那索引树上的数据就是按照addTime排好序的

问题2:给区分度高的字段加索引

比如我们给sex建立索引,而sex就两种,所以用sex过滤出来的数据可能会占到整张表的一大部分,可能不会用到索引

问题3:select的字段会导致回表

如果不需要那么多的字段,就不要select太多,这会导致回表,影响效率。能直接在二级索引树上取的就直接取,避免回表!

问题4:多个字段有索引,使用哪个索引?

一张表的一次查询只能用到1个索引,数据库引擎会比较用a=1过滤的数据和b=2过滤的数据,哪个索引过滤出来的数据少,就用哪个索引

问题5:内连接之大表和小表

内连接的时候,小表是整表扫描,每一个都要用到,大表相关联的字段没有索引的话,小表的每一个uid在大表中搜索都是整表搜索。如果大表相关联的字段有索引,小表的每一个uid在大表中就是走索引,搜的非常快。

确定大表还是小表:先用where进行数据过滤,谁的数据少谁就是小表

问题6:模糊搜索使用索引

第一个zhang%通配符在后面,可以利用索引进行前缀搜索,可以根据前缀的匹配缩小搜索范围。对于字符串类型来说,索引长度(key_len)不需要很长,只需要能区分每个字符串数据即可,索引过长,导致索引文件变大,创建索引树的时候花费的磁盘I/O也就多了

第二个%zhang%通配符在前面,可以匹配任意的数据,所以只能整张表搜索。如果不扫描完整张表,也不知道到底还有没有含有zhang的数据

问题7:in和not in是否能用到索引?not in优化成range范围搜索

实际上,MySQL做了如下优化:

csharp 复制代码
select age from student where age not in (20);
select age from student where age < 20 or age > 20;  -- 优化成了range范围搜索

not in 可以转化为范围range搜索查询

问题8:索引字段涉及函数以及类型转换,无法用到索引

本来是按照password排序作为索引的,经过函数计算之后就成为了另外的值,所以无法使用索引

索引字段涉及类型强转、mysql聚合函数调用、表达式计算等,不会使用索引

问题9:or不能使用索引?

or 实际上也可以用到索引,MySQL会对or进行优化成union联合查询

优化成union后的两个select应该是都可以使用索引的,究竟用不用,还得看使用索引是否能带来效率的提升

总结

相关推荐
霖霖总总5 分钟前
[小技巧19]MySQL 权限管理全指南:用户、角色、授权与安全实践
数据库·mysql·安全
uzong3 小时前
后端线上发布计划模板
后端
C雨后彩虹4 小时前
任务最优调度
java·数据结构·算法·华为·面试
uzong4 小时前
软件工程师应该关注的几种 UML 图
后端
heartbeat..5 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
上进小菜猪6 小时前
基于 YOLOv8 的 100 类中药材智能识别实战 [目标检测完整源码]
后端
麦聪聊数据7 小时前
MySQL并发与锁:从“防止超卖”到排查“死锁”
数据库·sql·mysql
码事漫谈7 小时前
AI 技能工程入门:从独立能力到协作生态
后端
码事漫谈7 小时前
构建高并发AI服务网关:C++与gRPC的工程实践
后端
AC赳赳老秦7 小时前
DeepSeek 私有化部署避坑指南:敏感数据本地化处理与合规性检测详解
大数据·开发语言·数据库·人工智能·自动化·php·deepseek