溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql 獲取執(zhí)行計劃的方法

發(fā)布時間:2020-07-25 04:15:34 來源:網絡 閱讀:394 作者:春秋小記 欄目:MySQL數據庫

mysql 獲取執(zhí)行計劃方法:
1.通過explain進行查看sql的執(zhí)行計劃;
2.通線程正在執(zhí)行的sql查看該sql的執(zhí)行計劃;

  explain進行查看sql的執(zhí)行計劃相對簡單,其實通線程正在執(zhí)行的sql查看執(zhí)行計劃也很簡單,那么為什么還需要第二種方式呢?

  因為日常工作會發(fā)現(xiàn)很多sql一直在執(zhí)行,執(zhí)行發(fā)生異常,如果把該sql拿出來執(zhí)行又很快,于是我們想獲取該sql執(zhí)行異常時候的執(zhí)行計劃,同時因為數據在時刻的變化,統(tǒng)計信息也有可能變化,有可能導致執(zhí)行計劃發(fā)生改變,好在mysql5.7開始已經可以通過正在執(zhí)行的線程查看該sql的執(zhí)行計劃,不需要把sql拿出來執(zhí)行獲取執(zhí)行計劃,這樣就可以很好的還原真相:

show processlist;或者select * from information_schema.PROCESSLIST where info is not null order by time desc ;查看。

mysql> select from information_schema.PROCESSLIST where info is not null;
+-----+------+-----------------+------+---------+------+--------------+-----------------------------------------------------------------------+
| ID | USER | HOST | DB | COMMAND | TIME | STATE | INFO |
+-----+------+-----------------+------+---------+------+--------------+-----------------------------------------------------------------------+
| 17 | root | localhost | NULL | Query | 0 | executing | select
from information_schema.PROCESSLIST where info is not null |
| 178 | root | localhost:60124 | app1 | Query | 560 | Sending data | select count(*) from t ,t_adress where t.adress = t_adress.adress |
+-----+------+-----------------+------+---------+------+--------------+-----------------------------------------------------------------------+
2 rows in set (0.00 sec)

mysql> EXPLAIN FOR CONNECTION 178;
+----+-------------+----------+------------+------+---------------+------+---------+------+--------+----------+----------------------------------------------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+----------+------------+------+---------------+------+---------+------+--------+----------+----------------------------------------------------+
| 1 | SIMPLE | t_adress | NULL | ALL | NULL | NULL | NULL | NULL | 200096 | 100.00 | NULL |
| 1 | SIMPLE | t | NULL | ALL | NULL | NULL | NULL | NULL | 309664 | 100.00 | Using where; Using join buffer (Block Nested Loop) |
+----+-------------+----------+------------+------+---------------+------+---------+------+--------+----------+----------------------------------------------------+
2 rows in set (0.01 sec)

使用起來是不是很方便?

最后說一句:
今天心里很憋屈,睡覺了。。。。。。。。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI