千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > mysql inner join为什么不走索引?

mysql inner join为什么不走索引?

来源:千锋教育
发布人:xqq
时间: 2023-10-11 23:07:14 1697036834

一、mysql inner join为什么不走索引

因为索引的优势是在大表中过滤出小的结果集进行联接,mysql inner join句根本没有任何过滤条件。另外表很小的话全表扫描比索引快。针对查询语句过慢的问题,首先使用explain关键字对sql的执行计划进行分析。发现整个查询过程中均没有使用索引,每个表的数据不大,但是三张表联合,数据量直接乘积量级了;

既然定位到索引问题,就去数据库查看表的索引信息,却发现相关字段已经建立了索引,但是查询过程中却未使用到索引;

使用左外连接时,数据库会以左表为驱动,右表被驱动,考虑使用inner join替换left join来观察数据库查询是否会进行优化,替换后使用explain发现retailer表作为了被驱动表,且使用了索引,但是customer两个表仍然未走索引,且耗时过长;

经过对关联表的结构进行深入对比,且对字段类型、长度、编码等信息对比后发现数据表的编码方式存在差异,retailer表中字段字符集格式为utf8mb4,而customer表中字符集格式为utf8;

将关联字段字符集统一后,使用left join左外连接仍然可以很好的命中索引,查询时间直接0.1s。

延伸阅读:

二、InnoDB是什么

InnoDB 是 MySQL 上名列前茅个提供外键约束的数据存储引擎,除了提供事务处理外,InnoDB 还支持行锁,提供和 Oracle 一样的一致性的不加锁读取,能增加并发读的用户数量并提高性能,不会增加锁的数量。InnoDB 的设计目标是处理大容量数据时最大化性能,它的 CPU 利用率是其他所有基于磁盘的关系数据库引擎中最有效率的。

InnoDB 是一套放在 MySQL 后台的完整数据库系统,InnoDB 有它自己的缓冲池,能缓冲数据和索引,InnoDB 还把数据和索引存放在表空间里面,可能包含好几个文件,这和 MyISAM 表完全不同,在 MyISAM 中,表被存放在单独的文件中,InnoDB 表的大小只受限于操作系统文件的大小,一般为 2GB。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT