EXPLAINtbl_name
Or:
EXPLAIN [EXTENDED | PARTITIONS] SELECTselect_options
EXPLAIN
statement can be used either as a synonym for DESCRIBE
or as a way to obtain information about how MySQL executes a SELECT
statement: -
EXPLAIN
is synonymous withtbl_name
DESCRIBE
ortbl_name
SHOW COLUMNS FROM
.tbl_name
-
When you precede a
SELECT
statement with the keywordEXPLAIN
, MySQL displays information from the optimizer about the query execution plan. That is, MySQL explains how it would process theSELECT
, including information about how tables are joined and in which order.
With the help of EXPLAIN
, you can see where you should add indexes to tables to get a faster SELECT
that uses indexes to find rows. You can also use EXPLAIN
to check whether the optimizer joins the tables in an optimal order. To force the optimizer to use a join order corresponding to the order in which the tables are named in the SELECT
statement, begin the statement with SELECT STRAIGHT_JOIN
rather than just SELECT
.
If you have a problem with indexes not being used when you believe that they should be, you should run ANALYZE TABLE
to update table statistics such as cardinality of keys, that can affect the choices the optimizer makes.
EXPLAIN
returns a row of information for each table used in the SELECT
statement. The tables are listed in the output in the order that MySQL would read them while processing the query. MySQL resolves all joins using a single-sweep multi-join method. This means that MySQL reads a row from the first table, and then finds a matching row in the second table, the third table, and so on. When all tables are processed, MySQL outputs the selected columns and backtracks through the table list until a table is found for which there are more matching rows. The next row is read from this table and the process continues with the next table.
When the EXTENDED
keyword is used, EXPLAIN
produces extra information that can be viewed by issuing a SHOW WARNINGS
statement following the EXPLAIN
statement. This information displays how the optimizer qualifies table and column names in the SELECT
statement, what the SELECT
looks like after the application of rewriting and optimization rules, and possibly other notes about the optimization process.
From: MySQL 5.1 Reference Manual
Hi ASM, Thanks for the post.
ReplyDelete-Jhon