explain顯示了mysql如何使用索引來處理select語句以及連接表。可以幫助選擇更好的索引和寫出更優化的查詢語句。
使用方法,在select語句前加上explain就可以了:
如:
| mysql> explain select * from kt_course order by create_time desc;+----+-------------+-----------+------+---------------+------+---------+------+------+----------------+| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |+----+-------------+-----------+------+---------------+------+---------+------+------+----------------+| 1 | SIMPLE | kt_course | ALL | NULL | NULL | NULL | NULL | 29 | Using filesort |+----+-------------+-----------+------+---------------+------+---------+------+------+----------------+1 row in set |
EXPLAIN列的解釋:
select_type
1) SIMPLE:簡單的SELECT,不實用UNION或者子查詢。
2) PRIMARY:最外層SELECT。
3) UNION:第二層,在SELECT之后使用了UNION。
4) DEPENDENT UNION:UNION語句中的第二個SELECT,依賴于外部子查詢。
5) UNION RESULT:UNION的結果。
6) SUBQUERY:子查詢中的第一個SELECT。
7) DEPENDENT SUBQUERY:子查詢中的第一個SELECT,取決于外面的查詢。
8) DERIVED:導出表的SELECT(FROM子句的子查詢)
table:顯示這一行的數據是關于哪張表的
type:這是重要的列,顯示連接使用了何種類型。從最好到最差的連接類型為const、eq_reg、ref、range、indexhe和ALL
possible_keys:顯示可能應用在這張表中的索引。如果為空,沒有可能的索引。可以為相關的域從WHERE語句中選擇一個合適的語句
key: 實際使用的索引。如果為NULL,則沒有使用索引。很少的情況下,MYSQL會選擇優化不足的索引。這種情況下,可以在SELECT語句中使用USE INDEX(indexname)來強制使用一個索引或者用IGNORE INDEX(indexname)來強制MYSQL忽略索引
key_len:使用的索引的長度。在不損失精確性的情況下,長度越短越好
ref:顯示索引的哪一列被使用了,如果可能的話,是一個常數
rows:MYSQL認為必須檢查的用來返回請求數據的行數
Extra:關于MYSQL如何解析查詢的額外信息。將在表4.3中討論,但這里可以看到的壞的例子是Using temporary和Using filesort,意思MYSQL根本不能使用索引,結果是檢索會很慢
extra列返回的描述的意義
關于MYSQL如何解析查詢的額外信息。將在表4.3中討論,但這里可以看到的壞的例子是Using temporary和Using filesort,意思MYSQL根本不能使用索引,結果是檢索會很慢
Distinct:一旦MYSQL找到了與行相聯合匹配的行,就不再搜索了
Not exists: MYSQL優化了LEFT JOIN,一旦它找到了匹配LEFT JOIN標準的行,就不再搜索了
新聞熱點
疑難解答