mysql inner join为什么不走索引?
一、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。

相关推荐HOT
更多>>
在 iPad 上运行 Windows 是什么体验?
一、在 iPad 上运行 Windows 是什么体验目前市面上有一些能够在 iPad 上运行 Windows 的应用程序,例如 Parallels Access、Splash较好、VMware ...详情>>
2023-10-14 19:14:27
vector, list, map等容器使用场合是什么?
一、vector, list, map等容器使用场合vector适用于对象简单,变化较小,并且频繁随机访问的场景。list适用经常进行插入和删除并且不经常随机访...详情>>
2023-10-14 14:59:11
分库分表的数据库和分布式数据库有什么区别?
一、分库分表的数据库和分布式数据库有什么区别分库分表的数据库:没有这种数据库,所谓分库分表,这是开发应用的程序员通过自己的代码、或者底...详情>>
2023-10-14 13:59:18
APP定制开发的难点有哪些?
一、APP定制开发的难点1、多平台适配不同的移动平台(如iOS和Android)具有不同的操作系统、开发语言和开发工具。在进行APP定制开发时,需要适...详情>>
2023-10-14 12:57:35