MySql性能調(diào)優(yōu)三(explain/desc執(zhí)行計劃)

前言

explian/desc可以幫助我們分析sql語句赢底,寫出高效sql語句粥脚,讓mysql查詢優(yōu)化器可以更好的工作慈鸠。
mysql查詢優(yōu)化器會盡可能的使用索引御雕,優(yōu)化器排除的數(shù)據(jù)行越多蛔屹,mysql找到匹配數(shù)據(jù)行就越快削樊。

用法

explain/desc + sql

explain select * from tbl_chain_bill where billid = 6

explain.png
key value means
id 1 查詢序列號
select_type SIMPLE 查詢類型
table tbl_chain_bill 表或派生表名
type const 掃描類型
possible_keys PRIMARY 可能用的索引,有多個
key PRIMARY 實際使用索引
key_len 8 使用的索引長度,在不損失精度下漫贞,長度越短越好
ref const 顯示索引的哪一列被使用了
rows 1 該語句掃描了多少行記錄
Extra (Null) sql語句額外信息甸箱,如排序分組等

分析

id

表示執(zhí)行select子句順序的標識。id相同迅脐,順序由上至下芍殖;id越大,越先執(zhí)行谴蔑。

select_type
  • SIMPLE:簡單SELECT豌骏,不使用UNION或子查詢等;
  • PRIMARY:查詢中若包含任何復雜的子部分隐锭,最外層的select被標記為PRIMARY窃躲;
  • UNION:UNION中的第二個或后面的SELECT語句;
  • UNION RESULT:UNION的結(jié)果钦睡;
  • SUBQUERY:子查詢中的第一個SELECT蒂窒;
  • DERIVED:派生表的SELECT,F(xiàn)ROM子句的子查詢荞怒;
  • UNCACHEABLE SUBQUERY:結(jié)果集不能緩存的子查詢洒琢。
table

表示數(shù)據(jù)來源于哪張表或派生表。

image.png
type

從上到下褐桌,性能由差到好

  • ALL:從頭到尾全表掃描纬凤;
  • Index:全索引樹掃描,只遍歷索引樹撩嚼;
  • Range:只檢索給定的范圍,需要使用一個索引來選擇行挖帘,key代表使用的索引完丽;
  • Ref:用于連接匹配的索引列不唯一時,如where bill.billNo = billDetail.billNo拇舀;
  • Eq ref:用于連接匹配的索引列是unique或者primary key時逻族,如where bill.id = billDetail.billID;
  • const:用常數(shù)來比較primary key時嗎骄崩,比如where primary key = 123聘鳞;
  • system:被查詢表只有一行記錄,用常數(shù)來比較primary key時要拂。
extra

extra 中出現(xiàn)以下 2 項意味著 MYSQL 根本不能使用索引抠璃,效率會受到重大影響,應(yīng)盡可能對此進行優(yōu)化脱惰。

Using filesort 表示 MySQL會對結(jié)果使用一個外部索引排序搏嗡,而不是從表里按索引次序讀到相關(guān)內(nèi)容。可能在內(nèi)存或者磁盤上進行排序采盒。

Using temporary 表示 MySQL 在對查詢結(jié)果排序時使用臨時表旧乞。常見于排序 order by 和分組查詢 group by。

測試說明

測試說明.png

需要指出的是磅氨,上面例子關(guān)于type=ref或者eq_ref是因為唯一索引的存在尺栖,如果連接條件沒有唯一性約束,那么還是記錄少的放在連接查詢的左邊烦租。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末延赌,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子左权,更是在濱河造成了極大的恐慌皮胡,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件赏迟,死亡現(xiàn)場離奇詭異屡贺,居然都是意外死亡,警方通過查閱死者的電腦和手機锌杀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進店門甩栈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人糕再,你說我怎么就攤上這事量没。” “怎么了突想?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵殴蹄,是天一觀的道長。 經(jīng)常有香客問我猾担,道長袭灯,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任绑嘹,我火速辦了婚禮稽荧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘工腋。我一直安慰自己姨丈,他們只是感情好,可當我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布擅腰。 她就那樣靜靜地躺著蟋恬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪趁冈。 梳的紋絲不亂的頭發(fā)上筋现,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天,我揣著相機與錄音,去河邊找鬼矾飞。 笑死一膨,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的洒沦。 我是一名探鬼主播豹绪,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼申眼!你這毒婦竟也來了瞒津?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤括尸,失蹤者是張志新(化名)和其女友劉穎巷蚪,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體濒翻,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡屁柏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了有送。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片淌喻。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖雀摘,靈堂內(nèi)的尸體忽然破棺而出裸删,到底是詐尸還是另有隱情,我是刑警寧澤阵赠,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布涯塔,位于F島的核電站,受9級特大地震影響清蚀,放射性物質(zhì)發(fā)生泄漏匕荸。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一轧铁、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧旦棉,春花似錦齿风、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至真屯,卻和暖如春脸候,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工运沦, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留泵额,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓携添,卻偏偏與公主長得像嫁盲,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子烈掠,可洞房花燭夜當晚...
    茶點故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內(nèi)容

  • 轉(zhuǎn) # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    呂品?閱讀 9,739評論 0 44
  • 1.explain 使用explain關(guān)鍵字分析SQL語句的效率與執(zhí)行情況是基礎(chǔ); 例: 各列的含義如下: id:...
    Separes閱讀 2,015評論 0 6
  • 7.2.1. EXPLAIN語法(獲取SELECT相關(guān)信息) EXPLAINtbl_name 或: EXPLAIN...
    followyounger1閱讀 688評論 0 2
  • 最近發(fā)現(xiàn)默默喜歡說好無聊啊羞秤,在她等待的時候她會說等待好無聊啊,還會說在家好無聊左敌,幼兒園不無聊瘾蛋,今天還說媽媽我想再上...
    大臉貓黑黑閱讀 144評論 0 0
  • 昨晚,為了一個人矫限,睡不著哺哼。哭泣了好久奇唤,但是不管怎樣幸斥,都回不去了。沒人會為你改變的咬扇。自己也不可能去受這樣的委屈甲葬。 他...
    娜樣非凡123閱讀 211評論 0 0