优化SQL语句小结
基本的思路:
優(yōu)化的基本原則:
1)? 永遠(yuǎn)用小結(jié)果集驅(qū)動大結(jié)果集
2)? 盡可能利用索引完成排序
3)? 自取自己需要的字段
4)? 僅僅使用最有效的過濾條件
5)? 盡可能避免復(fù)雜的Join和子查詢。
通過Query Profile查看一條Query獲取CPU、IO、IPC等資源消耗情況, 分析其性能瓶頸
具體做法如下:
1)? Set profiling=1 ????? 開啟Query Profiler功能
2)? Show Profiles:獲取保存多個Query的Profile的概要信息
3)? Show profile cpu, block io for query 6 針對單個Query獲取詳細(xì)的profile信息
查找待優(yōu)化的SQL
(1)???? 通過show status和應(yīng)用特點(diǎn)了解各種SQL的執(zhí)行頻率
通過SHOW STATUS可以提供服務(wù)器狀態(tài)信息,也可以使用mysqladmin extended-status命令獲得。SHOW STATUS可以根據(jù)需要顯示session級別的統(tǒng)計(jì)結(jié)果和global級別的統(tǒng)計(jì)結(jié)果。
以下幾個參數(shù)對Myisam和Innodb存儲引擎都計(jì)數(shù):
1.Com_select? 執(zhí)行select操作的次數(shù),一次查詢只累加1;
2.Com_insert 執(zhí)行insert操作的次數(shù),對于批量插入的insert操作,只累加一次;
3.Com_update 執(zhí)行update操作的次數(shù);
4.Com_delete 執(zhí)行delete操作的次數(shù);
?
以下幾個參數(shù)是針對Innodb存儲引擎計(jì)數(shù)的,累加的算法也略有不同:
1. Innodb_rows_read select查詢返回的行數(shù);
2. Innodb_rows_inserted執(zhí)行Insert操作插入的行數(shù);
3. Innodb_rows_updated 執(zhí)行update操作更新的行數(shù);
4. Innodb_rows_deleted 執(zhí)行delete操作刪除的行數(shù);
通過以上幾個參數(shù),可以很容易的了解當(dāng)前數(shù)據(jù)庫的應(yīng)用是以插入更新為主還是以查詢操作為主,以及各種類型的SQL大致的執(zhí)行比例是多少。對于更新操作的計(jì)數(shù),是對執(zhí)行次數(shù)的計(jì)數(shù),不論提交還是回滾都會累加。
?
對于事務(wù)型的應(yīng)用,通過Com_commit和Com_rollback可以了解事務(wù)提交和回滾的情況,對于回滾操作非常頻繁的數(shù)據(jù)庫,可能意味著應(yīng)用編寫存在問題。
此外,以下幾個參數(shù)便于我們了解數(shù)據(jù)庫的基本情況:
1.Connections 試圖連接Mysql服務(wù)器的次數(shù)
2.Uptime ?? 服務(wù)器工作時間
3.Slow_queries 慢查詢的次數(shù)
(2)???? 定位執(zhí)行效率較低的SQL語句
可以通過以下兩種方式定位執(zhí)行效率較低的SQL語句:
1.可以通過慢查詢?nèi)罩?/strong>定位那些執(zhí)行效率較低的sql語句,用--log-slow-queries[=file_name]選項(xiàng)啟動時,mysqld寫一個包含所有執(zhí)行時間超過long_query_time秒的SQL語句的日志文件。可以鏈接到管理維護(hù)中的相關(guān)章節(jié)。
?
2.慢查詢?nèi)罩驹诓樵兘Y(jié)束以后才紀(jì)錄,所以在應(yīng)用反映執(zhí)行效率出現(xiàn)問題的時候查詢慢查詢?nèi)罩静⒉荒芏ㄎ粏栴},可以使用show processlist命令查看當(dāng)前MySQL在進(jìn)行的線程,包括線程的狀態(tài),是否鎖表等等,可以實(shí)時的查看SQL執(zhí)行情況,同時對一些鎖表操作進(jìn)行優(yōu)化。
?
(3)???? 通過EXPLAIN分析低效SQL的執(zhí)行計(jì)劃
通過以上步驟查詢到效率低的SQL后,我們可以通過explain或者desc 獲取MySQL如何執(zhí)行SELECT語句的信息,包括select語句執(zhí)行過程表如何連接和連接的次序。
Explain可以知道什么時候必須為表加入索引以得到一個使用索引來尋找記錄的更快的SELECT。
?
select_type:select 類型
table:輸出結(jié)果集的表
type:表示表的連接類型
①當(dāng)表中僅有一行是type的值為system是最佳的連接類型;
②當(dāng)select操作中使用索引進(jìn)行表連接時type的值為ref;
③當(dāng)select的表連接沒有使用索引時,經(jīng)常會看到type的值為ALL,表示對該表進(jìn)行了全表掃描,這時需要考慮通過創(chuàng)建索引來提高表連接的效率。
possible_keys:表示查詢時,可以使用的索引列.
key:表示使用的索引
key_len:索引長度
rows:掃描范圍
Extra:執(zhí)行情況的說明和描述
(4)???? 確定問題,并采取相應(yīng)的優(yōu)化措施
經(jīng)過以上步驟,基本可以確認(rèn)問題出現(xiàn)的原因,可以根據(jù)情況采取相應(yīng)的措施,進(jìn)行優(yōu)化提高執(zhí)行的效率。
?
轉(zhuǎn)載于:https://www.cnblogs.com/mackxu/archive/2013/03/03/2942045.html
《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
- 上一篇: 一些有用的Linux命令
- 下一篇: Mysql遇到Too many conn