MySQL explain Query understanding

江枫思渺然 提交于 2019-11-27 00:06:13

问题


I've read on some blogs and in some articles related to optimization, how to optimize queries. I read I need to use indexes and make sure all my primary key and foreign keys are set correctly using a good relational database schema.

Now I have a query I need to optimize and I get this on the EXPLAIN:

Using where; Using temporary; Using filesort

I am using MySQL 5.5

I know I am using WHERE but not with my temporary table nor filesort? What does this mean?


回答1:


Using temporary means that MySQL need to use some temporary tables for storing intermediate data calculated when executing your query.

Using filesort is a sorting algorithm where MySQL isn't able to use an index for sorting and therefore can't do the complete sort in memory. Instead it breaks the sort into smaller chunks and then merge the results to get the final sorted data.

Please refer to http://dev.mysql.com/doc/refman/5.0/en/explain-output.html.

I think you might be using an ORDER BY plus some derived table or sub-query. It would be great if you could paste your query and relevant tables/indexes information and the EXPLAIN output.




回答2:


Syntax:

Explain `MySQL Query`

Example: EXPLAIN SELECT * FROM categoriesG

Example: EXPLAIN EXTENDED SELECT City.Name FROM City JOIN Country ON (City.CountryCode = Country.Code) WHERE City.CountryCode = 'IND' AND Country.Continent = 'Asia'G

Explain followed with your mysql query

Better explained in details here



来源:https://stackoverflow.com/questions/7999833/mysql-explain-query-understanding

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!