亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mysql explain的用法(使用explain優(yōu)化查詢語(yǔ)句)

 更新時(shí)間:2017年01月09日 22:42:29   投稿:mdxy-dxy  
mysql explain可以幫助你檢查索引和更好的優(yōu)化查詢語(yǔ)句,今天特地學(xué)習(xí)了下mysql explain的用法,需要的朋友可以參考下

首先我來(lái)給一個(gè)簡(jiǎn)單的例子,然后再來(lái)解釋explain列的信息。

表一:catefory 文章分類(lèi)表:

CREATE TABLE IF NOT EXISTS `category` ( 
 `id` smallint(5) unsigned NOT NULL AUTO_INCREMENT, 
 `name` varchar(50) NOT NULL DEFAULT '', 
 PRIMARY KEY (`id`) 
) ENGINE=MyISAM 
INSERT INTO `test`.`category` VALUES (NULL , '分類(lèi)1'); 
INSERT INTO `test`.`category` VALUES (NULL , '分類(lèi)2'); 
INSERT INTO `test`.`category` VALUES (NULL , '分類(lèi)3');

表二:article文章表:

CREATE TABLE IF NOT EXISTS `article` (
 `aid` int(11) NOT NULL,
 `cid` int(11) NOT NULL,
 `content` text NOT NULL,
 PRIMARY KEY (`aid`),
 KEY `cid` (`cid`)
) ENGINE=MyISAM
INSERT INTO `test`.`article` (`aid`, `cid`, `content`) VALUES ('', '7', '腳本之家(jb51.net)教程');

執(zhí)行explain:

EXPLAIN SELECT name, content
FROM category, article
WHERE category.id = article.cid

得到結(jié)果:

EXPLAIN列的解釋?zhuān)?/strong>

id:選定的執(zhí)行計(jì)劃中查詢的序列號(hào)。表示查詢中執(zhí)行select子句或操作表的順序,id值越大優(yōu)先級(jí)越高,越先被執(zhí)行。id相同,執(zhí)行順序由上至下。

select_type:查詢類(lèi)型 說(shuō)明

1、SIMPLE:簡(jiǎn)單的select查詢,不使用union及子查詢
2、PRIMARY:最外層的select查詢
3、UNION:UNION中的第二個(gè)或隨后的select查詢,不依賴(lài)于外部查詢的結(jié)果集
4、DEPENDENT UNION:UNION中的第二個(gè)或隨后的select查詢,依賴(lài)于外部查詢的結(jié)果集
5、UNION RESULT: UNION查詢的結(jié)果集SUBQUERY子查詢中的第一個(gè)select查詢,不依賴(lài)于外部查詢的結(jié)果集
6、DEPENDENT SUBQUERY:子查詢中的第一個(gè)select查詢,依賴(lài)于外部查詢的結(jié)果集DERIVED用于from子句里有子查詢的情況。
MySQL會(huì)遞歸執(zhí)行這些子查詢,把結(jié)果放在臨時(shí)表里。
7、UNCACHEABLE SUBQUERY:結(jié)果集不能被緩存的子查詢,必須重新為外層查詢的每一行進(jìn)行評(píng)估
8、UNCACHEABLE UNION:UNION中的第二個(gè)或隨后的select查詢,屬于不可緩存的子查詢

table:顯示這一行的數(shù)據(jù)是關(guān)于哪張表的
type:這是重要的列,顯示連接使用了何種類(lèi)型。從最好到最差的連接類(lèi)型為const、eq_reg、ref、range、index和ALL
all: full table scan ;mysql將遍歷全表以找到匹配的行;
index : index scan; index 和 all的區(qū)別在于index類(lèi)型只遍歷索引;
range:索引范圍掃描,對(duì)索引的掃描開(kāi)始于某一點(diǎn),返回匹配值的行,常見(jiàn)與between ,< ,>等查詢;
ref:非唯一性索引掃描,返回匹配某個(gè)單獨(dú)值的所有行,常見(jiàn)于使用非唯一索引即唯一索引的非唯一前綴進(jìn)行查找;
eq_ref:唯一性索引掃描,對(duì)于每個(gè)索引鍵,表中只有一條記錄與之匹配,常用于主鍵或者唯一索引掃描;
const,system:當(dāng)mysql對(duì)某查詢某部分進(jìn)行優(yōu)化,并轉(zhuǎn)為一個(gè)常量時(shí),使用這些訪問(wèn)類(lèi)型。如果將主鍵置于where列表中,mysql就能將該查詢轉(zhuǎn)化為一個(gè)常量。
possible_keys:顯示可能應(yīng)用在這張表中的索引。如果為空,沒(méi)有可能的索引??梢詾橄嚓P(guān)的域從WHERE語(yǔ)句中選擇一個(gè)合適的語(yǔ)句
key: 實(shí)際使用的索引。如果為NULL,則沒(méi)有使用索引。很少的情況下,MYSQL會(huì)選擇優(yōu)化不足的索引。這種情況下,可以在SELECT語(yǔ)句中使用USE INDEX(indexname)來(lái)強(qiáng)制使用一個(gè)索引或者用IGNORE INDEX(indexname)來(lái)強(qiáng)制MYSQL忽略索引
key_len:使用的索引的長(zhǎng)度。在不損失精確性的情況下,長(zhǎng)度越短越好
ref:顯示索引的哪一列被使用了,如果可能的話,是一個(gè)常數(shù)
rows:MYSQL認(rèn)為必須檢查的用來(lái)返回請(qǐng)求數(shù)據(jù)的行數(shù)
Extra:關(guān)于MYSQL如何解析查詢的額外信息。將在表4.3中討論,但這里可以看到的壞的例子是Using temporary和Using filesort,意思MYSQL根本不能使用索引,結(jié)果是檢索會(huì)很慢。
因?yàn)檎嬲膬?yōu)化會(huì)考慮到大數(shù)據(jù),我會(huì)在后面寫(xiě)更詳細(xì)的優(yōu)化教程,今天累了!分享一個(gè)詳細(xì)的mysql explain語(yǔ)法及使用教程(Mysql_Explain_語(yǔ)法詳細(xì)解析.pdf)!

相關(guān)文章

最新評(píng)論