国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL中EXPLAIN命令詳解

2024-07-24 12:46:48
字體:
來源:轉載
供稿:網友

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標準的行,就不再搜索了

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 弥渡县| 凤台县| 黔西| 巴林右旗| 海原县| 黎平县| 阳山县| 通州市| 深泽县| 清水河县| 从江县| 阿克苏市| 海阳市| 汤阴县| 浦北县| 璧山县| 理塘县| 通海县| 衡阳市| 峨边| 盐边县| 额济纳旗| 离岛区| 美姑县| 全南县| 阿拉善盟| 彭阳县| 新闻| 东莞市| 永胜县| 贺州市| 枣强县| 河西区| 郎溪县| 连江县| 吉林市| 于田县| 乐陵市| 扬州市| 宣化县| 秭归县|