搜尋
首頁資料庫mysql教程MySQL中explain的使用以及效能分析

MySQL中explain的使用以及效能分析

Dec 06, 2017 am 09:24 AM
explainmysql效能

MySQL 提供了一個EXPLAIN 指令, 它可以對SELECT 語句進行分析, 並輸出SELECT 執行的詳細資訊, 以供開發人員針對性最佳化.EXPLAIN 指令用法十分簡單,MySQL效能分析及explain用法的知識是本文我們主要要介紹的內容,接下來就讓我們透過一些實際的例子來介紹這個過程!

1.使用explain語句去查看分析結果

explain select * from test1 where id=1;

會出現:

id  selecttype  table  type possible_keys  key key_len  ref rows  extra各列。

其中,

type=const表示透過索引一次就找到了;

key=primary的話,表示使用了主鍵;

type=all,表示為全表掃描;

key=null表示沒用到索引。 type=ref,因為這時認為是多個符合行,在聯合查詢中,一般為REF。

2.MYSQL中的組合索引

假設表有id,key1,key2,key3,把三者形成一個組合索引,則

如:

where key1=....     
where key1=1 and key2=2     
where key1=3 and key3=3 and key2=2

根據最左原則,這些都是可以使用索引的,如from test where key1=1 order by key3,用explain分析的話,只用到了normal_key索引,但只對where子句起作用,而後面的order by需要排序。

3.使用慢查詢分析

在my.ini:

long_query_time=1
log-slow-queries=d:\mysql5\logs\mysqlslow.log

把超過1秒的記錄在慢查詢日誌中

可以用mysqlsla來分析之。也可以在mysqlreport中,有如

DMS分別分析了select ,update,insert,delete,replace等所佔的百份比

4.MYISAM和INNODB的鎖定

myisam中,注意是表鎖來的,例如在多個UPDATE操作後,再SELECT時,會發現SELECT操作被鎖定了,必須等所有UPDATE操作完畢後,再能SELECT

innodb的話則不同了,用的是行鎖,不存在上面問題。

5.MYSQL的交易配置項目

innodb_flush_log_at_trx_commit=1

表示事務提交時立即把交易日誌寫入磁盤,同時資料和索引也更新。

innodb_flush_log_at_trx_commit=0

事務提交時,不立即把交易日誌寫入磁碟,每隔1秒寫一次

innodb_flush_log_at_trx_commit=2

事務提交時,立即寫入磁碟檔案(這裡只是寫入到核心緩衝區,但不立即刷新到磁碟,而是每隔1秒刷新到磁碟,同時更新資料和索引

explain用法


##

EXPLAIN tbl_name或:EXPLAIN [EXTENDED] SELECT select_options

前者可以得出一個表的字段結構等等,後者主要是給出相關的一些索引信息,而今天要講述的重點是後者。 #
mysql> explain select * from event;  
+—-+————-+——-+——+—————+——+———+——+——+——-+  
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |  
+—-+————-+——-+——+—————+——+———+——+——+——-+  
| 1 | SIMPLE | event | ALL | NULL | NULL | NULL | NULL | 13 | |  
+—-+————-+——-+——+—————+——+———+——+——+——-+  
1 row in set (0.00 sec)

各個

屬性的意思id

select查詢的序號

select_type

select查詢的類型,主要是區別普通查詢和聯合查詢、子查詢之類的複雜查詢。的類型。 ,最好能達到ref。效能,可透過檢驗WHERE子句,看是否引用某些字段,或檢查字段不是適合索引。鍵是NULL。了哪一部分。找到,在innodb上是不準確的。 。顯示Using filesort或Using temporary的話會很吃力,WHERE和ORDER BY的索引經常無法兼顧,如果按照WHERE來確定索引,那麼在ORDER BY時,就必然會引起Using filesort,這就要看是先過濾再排序划算,還是先排序再過濾划算。

總結:

關於MySQL效能分析及explain用法的知識就介紹到這裡了,相信小夥伴對此也是有了一定的了解!

相關推薦:

#MysqlEXPLAIN作用

#

mysql慢查詢和EXPLAIN的相關介紹

#MySQL查詢效能分析工具-explain關鍵字分析

mysql explain type連線類型範例

#

以上是MySQL中explain的使用以及效能分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
將用戶添加到MySQL:完整的教程將用戶添加到MySQL:完整的教程May 12, 2025 am 12:14 AM

掌握添加MySQL用戶的方法對於數據庫管理員和開發者至關重要,因為它確保數據庫的安全性和訪問控制。 1)使用CREATEUSER命令創建新用戶,2)通過GRANT命令分配權限,3)使用FLUSHPRIVILEGES確保權限生效,4)定期審計和清理用戶賬戶以維護性能和安全。

掌握mySQL字符串數據類型:varchar vs.文本與char掌握mySQL字符串數據類型:varchar vs.文本與charMay 12, 2025 am 12:12 AM

chosecharforfixed-lengthdata,varcharforvariable-lengthdata,andtextforlargetextfield.1)chariseffity forconsistent-lengthdatalikecodes.2)varcharsuitsvariable-lengthdatalikenames,ballancingflexibilitibility andperformance.3)

MySQL:字符串數據類型和索引:最佳實踐MySQL:字符串數據類型和索引:最佳實踐May 12, 2025 am 12:11 AM

在MySQL中處理字符串數據類型和索引的最佳實踐包括:1)選擇合適的字符串類型,如CHAR用於固定長度,VARCHAR用於可變長度,TEXT用於大文本;2)謹慎索引,避免過度索引,針對常用查詢創建索引;3)使用前綴索引和全文索引優化長字符串搜索;4)定期監控和優化索引,保持索引小巧高效。通過這些方法,可以在讀取和寫入性能之間取得平衡,提升數據庫效率。

mysql:如何遠程添加用戶mysql:如何遠程添加用戶May 12, 2025 am 12:10 AM

ToaddauserremotelytoMySQL,followthesesteps:1)ConnecttoMySQLasroot,2)Createanewuserwithremoteaccess,3)Grantnecessaryprivileges,and4)Flushprivileges.BecautiousofsecurityrisksbylimitingprivilegesandaccesstospecificIPs,ensuringstrongpasswords,andmonitori

MySQL字符串數據類型的最終指南:有效的數據存儲MySQL字符串數據類型的最終指南:有效的數據存儲May 12, 2025 am 12:05 AM

tostorestringsefliceflicyInmySql,ChooSetherightDataTypeBasedyOrneOrneEds:1)USEcharforFixed-LengthStstringStringStringSlikeCountryCodes.2)UseVarcharforvariable-lengtthslikenames.3)USETEXTCONTENT.3)

MySQL:字符串數據類型可用哪些字符集?MySQL:字符串數據類型可用哪些字符集?May 10, 2025 am 12:07 AM

mysqloffersvariouscharactersetsforstringdatatypes:1)latin1 forwesterneuropeanlanguages,2)utf8 formultingualsupport,3)utf8mb4f OREXTEDENDENDENENICODECLUDINGEMOJIS,4)UCS2FORIXED-WIDTHENCODING,5)assiiforbasiclatin.ChoosideStherightStetSetensensersdaintegrity

mysql:斑點流比存儲它們更好嗎?mysql:斑點流比存儲它們更好嗎?May 10, 2025 am 12:06 AM

流式傳輸BLOB確實比直接存儲更好,因為它能減少內存使用和提高性能。 1)通過逐步讀取和處理文件,避免了數據庫膨脹和性能下降。 2)流式傳輸需要更複雜的代碼邏輯,且可能增加I/O操作次數。

MySQL字符串類型:存儲,性能和最佳實踐MySQL字符串類型:存儲,性能和最佳實踐May 10, 2025 am 12:02 AM

mySqlStringTypesimpactStorageAndPerformanCeaseAsfollows:1)長度,始終使用theSamestoragespace,whatcanbefasterbutlessspace-felfficity.2)varCharisvariable varcharisvariable length,morespace-morespace-morespace-effficitybuteftife buteftife butfority butfority textifforlyslower.3)

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境