介紹
MySQL 是一種開源的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),廣泛應(yīng)用于各種 Web 應(yīng)用程序中,并且擁有多種優(yōu)良特性,比如高性能、可靠、易用等等。在進(jìn)行 MySQL 數(shù)據(jù)庫(kù)操作時(shí),如果需要查看 SQL 查詢的運(yùn)行時(shí)間,有幾種簡(jiǎn)單而有效的方法。
使用 MySQL 內(nèi)置功能查看查詢運(yùn)行時(shí)間
MySQL 提供了內(nèi)置的 PROFILING 功能,用于追蹤與記錄 SQL 查詢語(yǔ)句在服務(wù)器端的執(zhí)行信息。具體步驟如下:
- 打開 MySQL 控制臺(tái)
- 輸入 SHOW PROFILES; 查詢當(dāng)前環(huán)境下的所有 PROFILE,得到一個(gè) ID 列表
- 輸入 SET profiling=1;,表示開啟 PROFILING 功能
- 執(zhí)行一條 SQL 查詢語(yǔ)句,例如 SELECT * FROM users;
- 再次執(zhí)行 SHOW PROFILES; 查詢所有 PROFILE,得到一個(gè)新的 ID 列表,其中最新的 ID 對(duì)應(yīng)的記錄即為上一次執(zhí)行的 SQL 查詢語(yǔ)句的信息
- 輸入 SHOW PROFILE FOR QUERY n; (其中 n 即為剛剛獲取的 ID),即可查看在服務(wù)器端執(zhí)行這條 SQL 查詢語(yǔ)句耗費(fèi)的時(shí)間、所執(zhí)行的命令數(shù)量、內(nèi)核頁(yè)大小等等信息。
使用外部工具查看查詢運(yùn)行時(shí)間
實(shí)際上,MySQL 也可以通過其他外部工具來檢測(cè) SQL 查詢語(yǔ)句的運(yùn)行時(shí)間。例如,采用 MySQL 自帶的監(jiān)管工具 - MySQL Enterprise Monitor。其具有一套完整的監(jiān)控系統(tǒng),可以從多方面監(jiān)測(cè)、記錄 MySQL 數(shù)據(jù)庫(kù)的運(yùn)行狀態(tài)和 SQL 查詢語(yǔ)句的性能。用戶可以通過查詢監(jiān)視器儀表板或者導(dǎo)出監(jiān)控日志文件等方式,得到相應(yīng) SQL 查詢語(yǔ)句的運(yùn)行時(shí)間等信息。
小結(jié)
無論是使用 MySQL 內(nèi)部工具,還是采用其他外部監(jiān)管工具,都可以方便地查看 SQL 查詢語(yǔ)句的運(yùn)行時(shí)間,幫助用戶識(shí)別性能瓶頸,更好地進(jìn)行 SQL 優(yōu)化。當(dāng)然,用戶也可以選擇其他工具來查看 SQL 查詢語(yǔ)句的耗時(shí),例如 Navicat、phpMyAdmin 等第三方數(shù)據(jù)庫(kù)管理軟件。