一、MySQL数据库表上做查询慢的原因
我们还分析了执行计划改写后的SQL,通过猜测,增加了hint来解决问题:
这一期,我们通过工具来分析一下:MySQL为什么会使用一个低效的执行计划,以致于我们不得已用hint来调优SQL?
实验
我们接着使用26问中的环境,使用optimizertrace工具,观察MySQL对SQL的优化处理过程。
我们先调大optimizertrace的内存容量(否则trace的输出会被截断),然后开启了optimizertrace功能。
跑完SQL后,可以在INFORMATION_SCHEMA.OPTIMIZER_TRACE看到SQL的优化处理过程:
这会是个巨大的json,我们将其复制出来,找个json的可视化编辑器来分析一下。
小贴士
如果MySQL启动时有配置--secure-file-priv,那可以用,
SELECTTRACEINTODUMPFILE<filename>FROMINFORMATION_SCHEMA.OPTIMIZER_TRACE;
将trace导出到文件里,会更方便一些。
这里我们选择了一个在