Table of Contents
How to Use EXPLAIN
Key Columns in EXPLAIN Output
Practical Tips for Using EXPLAIN
EXPLAIN vs. EXPLAIN FORMAT=JSON
Final Notes
Home Database Mysql Tutorial What is the EXPLAIN statement and how to use it in MySQL?

What is the EXPLAIN statement and how to use it in MySQL?

Aug 22, 2025 am 07:27 AM
mysql explain

EXPLAIN in MySQL is used to analyze query execution plans without running the query, helping identify performance issues. 1. Use EXPLAIN before a SELECT, INSERT, UPDATE, DELETE, or REPLACE statement, most commonly with SELECT. 2. Key output columns include id, select_type, table, type, possible_keys, key, key_len, ref, rows, filtered, and Extra. 3. The type column should ideally show const, eq_ref, or ref, while avoiding ALL, which indicates a full table scan. 4. Check if key is NULL despite indexes listed in possible_keys, indicating no index is used, so consider adding or modifying indexes. 5. A high value in rows suggests inefficiency; reduce it with better indexing. 6. Avoid Using temporary and Using filesort in the Extra column, as they indicate expensive operations. 7. Create composite indexes, such as (city, age), to eliminate filesorts when filtering and sorting. 8. Use EXPLAIN FORMAT=JSON for more detailed, structured insights including optimizer decisions. 9. For actual execution metrics, use EXPLAIN ANALYZE in MySQL 8.0.18 . Regular use of EXPLAIN improves query efficiency and overall database performance.

What is the EXPLAIN statement and how to use it in MySQL?

The EXPLAIN statement in MySQL is a tool that shows how the database engine executes a query. It provides insight into how MySQL uses indexes, joins tables, filters rows, and organizes data retrieval. By using EXPLAIN, you can identify performance bottlenecks and optimize slow queries.

You use EXPLAIN by placing it before a SELECT, INSERT, UPDATE, DELETE, or REPLACE statement. However, it's most commonly used with SELECT queries to analyze execution plans.

How to Use EXPLAIN

To use EXPLAIN, simply prepend it to your SQL query:

EXPLAIN SELECT * FROM users WHERE age > 30;

This will return a result set with several columns that describe how MySQL plans to execute the query.

Key Columns in EXPLAIN Output

Each row in the output corresponds to a table used in the query. Important columns include:

  • id: The identifier for the query or subquery. Higher numbers may indicate subqueries or dependent queries.
  • select_type: Indicates the type of query (e.g., SIMPLE, PRIMARY, SUBQUERY, DERIVED).
  • table: The name of the table being accessed.
  • partitions: Shows which partitions are used (if partitioning is enabled).
  • type: The join type, which reflects how MySQL accesses the rows. Common values (from best to worst):
    • system / const: Only one or zero rows matched (very fast).
    • eq_ref: Primary key or unique index used in a join.
    • ref: Non-unique index used to match rows.
    • range: Index is used to retrieve a range of values.
    • index: Full index scan (slower than range).
    • ALL: Full table scan (usually a performance red flag).
  • possible_keys: Lists indexes MySQL could use for this query.
  • key: The actual index chosen by the optimizer.
  • key_len: Length of the key used; shorter is generally better.
  • ref: Shows which column or constant is used with the key.
  • rows: Estimated number of rows MySQL must examine. Lower is better.
  • filtered: Percentage of rows filtered by the table condition (introduced in MySQL 5.7).
  • Extra: Additional information, such as:
    • Using where: Applying a WHERE clause.
    • Using index: Index covers all needed columns (fast).
    • Using temporary: Creating a temporary table (can be slow).
    • Using filesort: Sorting data externally (avoid if possible).

Practical Tips for Using EXPLAIN

  • Check the type column: Aim for const, eq_ref, or ref. Avoid ALL unless dealing with very small tables.
  • Look at key and possible_keys: If key is NULL, MySQL isn’t using an index. Consider adding or adjusting indexes.
  • Watch the rows estimate: A high number suggests inefficiency. Try to reduce it with better indexing or query structure.
  • Minimize Using temporary and Using filesort: These operations are expensive. Optimize queries with proper indexing and avoid unnecessary sorting or grouping.

For example, if you see:

EXPLAIN SELECT name FROM users WHERE city = 'New York' ORDER BY age;

And the output shows Using filesort, you might create a composite index on (city, age) to avoid sorting.

EXPLAIN vs. EXPLAIN FORMAT=JSON

MySQL also supports EXPLAIN FORMAT=JSON, which gives a more detailed, structured output including cost estimates and optimizer decisions:

EXPLAIN FORMAT=JSON SELECT * FROM users WHERE age > 30;

This is useful for deeper analysis, especially in complex queries.

Final Notes

EXPLAIN doesn’t run the query—it only shows the execution plan. To see actual performance, consider EXPLAIN ANALYZE (available in MySQL 8.0.18 ), which executes the query and shows real timing and row counts.

Using EXPLAIN regularly helps write efficient queries and maintain good database performance. It’s a must-have tool for developers and DBAs working with MySQL.

The above is the detailed content of What is the EXPLAIN statement and how to use it in MySQL?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

ArtGPT

ArtGPT

AI image generator for creative art from text prompts.

Stock Market GPT

Stock Market GPT

AI powered investment research for smarter decisions

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to use a CASE statement in MySQL? How to use a CASE statement in MySQL? Sep 20, 2025 am 02:00 AM

The answer is: MySQL's CASE statement is used to implement conditional logic in query, and supports two forms: simple and search. Different values ​​can be dynamically returned in clauses such as SELECT, WHERE, and ORDERBY; for example, in SELECT, classification of scores by fractional segments, combining aggregate functions to count the number of states, or prioritizing specific roles in ORDERBY, it is necessary to always end with END and it is recommended to use ELSE to handle the default situation.

How to Automate MySQL Backups with a Script? How to Automate MySQL Backups with a Script? Sep 21, 2025 am 02:24 AM

Create a shell script containing the database configuration and mysqldump command and save it as mysql_backup.sh; 2. Store MySQL credentials by creating ~/.my.cnf file and set 600 permissions to improve security, modify the script to use configuration file authentication; 3. Use chmod x to make the script executable and manually test whether the backup is successful; 4. Add timed tasks through crontab-e, such as 02/path/to/mysql_backup.sh>>/path/to/backup/backup.log2>&1, realize automatic backup and logging at 2 a.m. every day; 5.

How to use subqueries in MySQL? How to use subqueries in MySQL? Sep 20, 2025 am 01:07 AM

Subqueries can be used in WHERE, FROM, SELECT, and HAVING clauses to implement filtering or calculation based on the result of another query. Operators such as IN, ANY, ALL are commonly used in WHERE; alias are required as derivative tables in FROM; single values ​​must be returned in SELECT; related subqueries rely on outer query to execute each row. For example, check employees whose average salary is higher than the department, or add the company average salary list. Subqueries improve logical clarity, but performance may be lower than JOIN, so you need to ensure that you return the expected results.

How to update a row if it exists or insert if not in MySQL How to update a row if it exists or insert if not in MySQL Sep 21, 2025 am 01:45 AM

INSERT...ONDUPLICATEKEYUPDATE implementation will be updated if it exists, otherwise it will be inserted, and it requires unique or primary key constraints; 2. Reinsert after deletion of REPLACEINTO, which may cause changes in the auto-increment ID; 3. INSERTIGNORE only inserts and does not repetitive data, and does not update. It is recommended to use the first implementation of upsert.

How to use the EXPLAIN command in MySQL? How to use the EXPLAIN command in MySQL? Sep 18, 2025 am 01:48 AM

EXPLAINinMySQLrevealsqueryexecutionplans,showingindexusage,tablereadorder,androwfilteringtooptimizeperformance;useitbeforeSELECTtoanalyzesteps,checkkeycolumnsliketypeandrows,identifyinefficienciesinExtra,andcombinewithindexingstrategiesforfasterqueri

How to select distinct values in MySQL? How to select distinct values in MySQL? Sep 16, 2025 am 12:52 AM

Use the DISTINCT keyword to remove duplicate values ​​from the specified column and return unique values. 1. The basic syntax is SELECTDISTINCTcolumn_nameFROMtable_name; 2. Query the unique value of a single column, such as SELECTDISTINCTcityFROMcustomers; 3. Query the unique combination of multiple columns, such as SELECTDISTINCTcity, stateFROMcustomers; 4. Filter with the WHERE clause and get the unique value, such as SELECTDISTINCTproduct_nameFROMordersWHEREorder_date>'202

How to calculate distance between two points in MySQL How to calculate distance between two points in MySQL Sep 21, 2025 am 02:15 AM

MySQL can calculate geographical distances through the Haversine formula or the ST_Distance_Sphere function. The former is suitable for all versions, and the latter provides easier and more accurate spherical distance calculations since 5.7.

How to handle timezones in MySQL? How to handle timezones in MySQL? Sep 20, 2025 am 04:37 AM

Use UTC to store time, set the MySQL server time zone to UTC, use TIMESTAMP to realize automatic time zone conversion, adjust the time zone according to user needs in the session, display the local time through the CONVERT_TZ function, and ensure that the time zone table is loaded.

See all articles