|
|
|
|
7.2.15. How to Avoid Table Scans
The output from EXPLAIN shows
ALL in the type column
when MySQL uses a table scan to resolve a query. This usually
happens under the following conditions:
The table is so small that it is faster to perform a table
scan than to bother with a key lookup. This is common for
tables with fewer than 10 rows and a short row length.
There are no usable restrictions in the
ON or WHERE clause for
indexed columns.
You are comparing indexed columns with constant values and
MySQL has calculated (based on the index tree) that the
constants cover too large a part of the table and that a
table scan would be faster. See
Section 7.2.4, “WHERE Clause Optimization”.
You are using a key with low cardinality (many rows match
the key value) through another column. In this case, MySQL
assumes that by using the key it probably will do many key
lookups and that a table scan would be faster.
For small tables, a table scan often is appropriate and the
performance impact is negligible. For large tables, try the
following techniques to avoid having the optimizer incorrectly
choose a table scan:
Use ANALYZE TABLE
tbl_name to update the
key distributions for the scanned table. See
Section 13.5.2.1, “ANALYZE TABLE Syntax”.
-
Use FORCE INDEX for the scanned table to
tell MySQL that table scans are very expensive compared to
using the given index:
SELECT * FROM t1, t2 FORCE INDEX (index_for_column )
WHERE t1.col_name =t2.col_name ;
See Section 13.2.7, “SELECT Syntax”.
Start mysqld with the
--max-seeks-for-key=1000 option or use
SET max_seeks_for_key=1000 to tell the
optimizer to assume that no key scan causes more than 1,000
key seeks. See Section 5.2.2, “Server System Variables”.
|
|
|