這篇文章為大家帶來了關於mysql的相關知識,其中主要介紹了慢日誌查詢的相關問題,還包括了show profiles查看sql具體的運行時間等相關內容,希望對大家有幫助。
推薦學習:mysql影片教學
#對於SQL和索引的最佳化問題,我們會使用explain去分析SQL語句。但真正的企業級專案有成千上萬條SQL,我們不可能從頭開始一條一條explain去分析。我們從什麼地方可以取得那些運行時間長,耗效能的SQL? ?
我們可以開啟慢查詢日誌:
根據特定的業務和並發量來預估一個時間上限(20ms、100ms),設定好後開啟業務,壓測後開啟慢查詢日誌,就會看到超過執行時間的SQL,然後使用explain分析這些耗時的SQL語句
步驟如下:
打開慢查詢日誌開關slow_query_log
設定合理的、業務可以接受的慢查詢時間上限
(MySQL定義的很多的全局的開關,都是在全局變數中存儲,可以用
show/set variables查看或設定全域變數的值)
慢查詢日誌開關預設是關閉的
慢查詢日誌的路徑:預設在
/var/lib/mysql/下
# 這個值是可以修改的:
開啟慢查詢日誌開關成功!
看另一個session
發現還是預設的10s,故long_query_time只影響當前session
已經超過我們設定的long_query_time=0.1s
/var/lib/mysql/
#
# 做了整表的搜索,把主鍵索引樹整個掃了一遍。
我們應該要為password加上索引,然後記得password是字串格式,因為如果涉及型別轉換是用不了索引的
MySQL一般只顯示小數點後兩位的時間
開啟profiling開關,顯示更詳細的時間
沒有報錯,表示profiling變數只影響目前session
推薦學習:mysql影片教學
以上是詳細了解MySQL慢日誌查詢的詳細內容。更多資訊請關注PHP中文網其他相關文章!