作者:Oo若離oO
來自:https://my.oschina.net/ruoli/blog/1807394
1、什麼是MySQL執行計劃
要對執行計劃有個比較好的理解,需要先對MySQL的基礎結構及查詢基本原理有簡單的瞭解。
MySQL本身的功能架構分為三個部分,分別是 應用層、邏輯層、物理層,不只是MySQL ,其他大多數資料庫產品都是按這種架構來進行劃分的。
-
應用層,主要負責與客戶端進行互動,建立連結,記住連結狀態,傳回資料,響應請求,這一層是和客戶端打交道的。
-
邏輯層,主要負責查詢處理、事務管理等其他資料庫功能處理,以查詢為例。
首先接收到查詢SQL之後,資料庫會立即分配一個執行緒對其進行處理,第一步查詢處理器會對SQL查詢進行最佳化,最佳化後會生成執行計劃,然後交由計劃執行器來執行。
計劃執行器需要訪問更底層的事務管理器,儲存管理器來運算元據,他們各自的分工各有不同,最終透過呼叫物理層的檔案獲取到查詢結構資訊,將最終結果響應給應用層。
-
物理層,實際物理磁碟上儲存的檔案,主要有分文資料檔案,日誌檔案。
透過上面的描述,生成執行計劃是執行一條SQL必不可少的步驟,一條SQL效能的好壞,可以透過檢視執行計劃很直觀的看出來,執行計劃提供了各種查詢型別與級別,方面我們進行檢視以及為作為效能分析的依據。
2、如何分析執行計劃
MySQL為我們提供了 explain 關鍵字來直觀的檢視一條SQL的執行計劃。
explain顯示了MySQL如何使用索引來處理select陳述句以及連線表,可以幫助選擇更好的索引和寫出更最佳化的查詢陳述句。
下麵我們使用 explain 做一個查詢,如下:
mysql> explain select * from payment;
+—-+————-+———+————+——+—————+——+———+——+——-+———-+——-+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+—-+————-+———+————+——+—————+——+———+——+——-+———-+——-+
| 1 | SIMPLE | payment | NULL | ALL | NULL | NULL | NULL | NULL | 16086 | 100.00 | NULL |
+—-+————-+———+————+——+—————+——+———+——+——-+———-+——-+
1 row in set, 1 warning (0.01 sec)
查詢結構中有12列,理解每一列的含義,對理解執行計劃至關重要,下麵用一個表格的形式進行說明。
列名 | 說明 |
---|---|
id | SELECT識別符,這是SELECT的查詢序列號。 |
select_type |
SELECT型別,可以為以下任何一種:
|
table | 輸出的行所取用的表 |
partitions | 如果查詢是基於分割槽表的話,顯示查詢將訪問的分割槽。 |
type |
聯接型別。下麵給出各種聯接型別,按照從最佳型別到最壞型別進行排序:
一般來說,得保證查詢至少達到range級別,最好能達到ref。 |
possible_keys | 指出MySQL能使用哪個索引在該表中找到行 |
key | 顯示MySQL實際決定使用的鍵(索引)。如果沒有選擇索引,鍵是NULL。 |
key_len | 顯示MySQL決定使用的鍵長度。如果鍵是NULL,則長度為NULL。在不損失精確性的情況下,長度越短越好 |
ref | 顯示使用哪個列或常數與key一起從表中選擇行。 |
rows | 顯示MySQL認為它執行查詢時必須檢查的行數。多行之間的資料相乘可以估算要處理的行數。 |
filtered | 顯示了透過條件過濾出的行數的百分比估計值。 |
Extra |
該列包含MySQL解決查詢的詳細資訊
|
根據上述表格,可以在執行計劃分析上提供很好的幫助。
●編號320,輸入編號直達本文
●輸入m獲取文章目錄
Web開發
更多推薦《18個技術類公眾微信》
涵蓋:程式人生、演演算法與資料結構、駭客技術與網路安全、大資料技術、前端開發、Java、Python、Web開發、安卓開發、iOS開發、C/C++、.NET、Linux、資料庫、運維等。