Mysql數據庫的慢sql優化步驟


Mysql數據庫的慢sql優化步驟

慢sql優化步驟:

  1. 先查看慢日志,獲得具體哪條sql語句是慢sql。
  2. 再使用explain sql語句,進行對慢sql分析。
  3. 修改sql語句,或者增加索引。

在數據庫可視化工具中,顯示有關慢日志的信息:

show variables like '%quer%';

 


Image.png

 

主要是查看這三個字段的信息:
long_query_time:sql執行多久才算慢sql,默認是10s;
slow_query_log:慢日志是否開啟,默認是OFF;
slow_query_log_file:慢日志存放的位置

想要永久的修改屬性,那么就要去數據庫的安裝目錄去修改my.ini文件,linux系統的話,那就就是my.cnf文件。
若只是想在單次連接中(下次重啟mysql服務就失效)修改屬性,那么可以直接使用set global 屬性名=修改屬性值;注意:在執行了該條語句之后,需要用終端重新連接mysql數據庫。

 


1596534119268-Image.png

 

將long_query_time設置回1s;

執行一條sql;查找單個字段,不走索引;(表中的數據有40萬條左右)

 


1596534119269-Image.png

 

再打開慢日志查看最新一條慢sql:

 


1596534119270-Image.png

 

可以看見query_time是1.8s,所以就是剛剛執行的那條sql就是慢sql了。

接着使用explain分析慢sql;

主要分析type和extra字段屬性;如果type為index或者all那么走的就是全表查詢,很大可能性是慢sql;
還有一個extra字段,如果是using filesort:文件排序(沒有利用索引排序的操作),或是using temporary:在對查詢結果排序時使用了臨時表,常見的order by和分組group by;

優化慢sql:讓sql走索引;修改sql語句。

修改上條sql語句,將motto字段設置成索引字段:

alter table person_info_large add index idx_mot(motto);

 


1596534119271-Image.png

 

查詢時間小於1s;不計入慢日志;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM