2024MySQL查詢優(yōu)化操作指南_第1頁
2024MySQL查詢優(yōu)化操作指南_第2頁
2024MySQL查詢優(yōu)化操作指南_第3頁
2024MySQL查詢優(yōu)化操作指南_第4頁
2024MySQL查詢優(yōu)化操作指南_第5頁
已閱讀5頁,還剩54頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

只查詢一條數(shù)據(jù)為什么執(zhí)行這同樣的邏輯,不同SQL執(zhí)行時(shí)間差這業(yè)務(wù)代碼沒有變更,SQL返回時(shí)間數(shù)據(jù)庫服務(wù)器負(fù)載居高不下,要優(yōu)化,這么多SQLMySQL邏輯怎么發(fā)現(xiàn)和定位慢MySQL是如何訪問MySQL的優(yōu)分析執(zhí)行計(jì)怎么發(fā)現(xiàn)慢從當(dāng)前查詢中獲取問題從慢日志中獲取問題sysschema相關(guān)視圖中獲取問題查看MySQL服務(wù)器內(nèi)部當(dāng)前線程正在執(zhí)除非具有process權(quán)限,否則只能看到自己發(fā)起的線Select*fromShow[full]processlist;不使用full則只顯示info字段前100ID:連接標(biāo)識(shí)。等于pefoance_cheathea表的RCESSLIST_ID字段,與CNNECTN_)函數(shù)返回值相同;如果需要k一個(gè)查詢需要用到它;HOST:發(fā)出該語句的客戶端主機(jī)名或者Db:該線程連接的數(shù)據(jù)庫Command:該連接當(dāng)前執(zhí)行的命令或狀態(tài)sleep(休眠),query(查詢)等等Time:線程處于當(dāng)前狀態(tài)的時(shí)間,單Info:線程正在執(zhí)行的語句或Slowquerylog記錄執(zhí)行時(shí)間超過long_query_time的SQL,并且至少需要檢查min_examined_row_limitslow_query_log參數(shù)決定慢查詢long_query_time支持微秒級(jí)TABLE,ANALYZETABLE,CHECKTABLE,CREATEINDEX,DROPINDEX,OPTIMIZETABLE,andREPAIRqueesnusnndexes參數(shù)開啟后,所有(表數(shù)據(jù)大于2行)不使用索引的查詢會(huì)被記錄。如果這類查詢較多,可以使用參數(shù)hequeesnusnndexes限制;log_throttle_queries_not_using_indexes每分鐘有多少不使用索引的查詢可被記錄在慢查詢Time:log記錄的時(shí)間 User@Host:SQL執(zhí)行的用戶以及主機(jī) id:連接的標(biāo)識(shí)Query_time:SQL執(zhí)行的時(shí)間 Lock_time:獲取鎖的時(shí)間Rows_sent:返回客戶端的結(jié)果行數(shù) Rows_examined:server層檢查的行數(shù)Thread_id:連接的標(biāo)識(shí) Errno:SQL錯(cuò)誤號(hào),0表示沒有錯(cuò)誤Killed:語句終止的錯(cuò)誤號(hào),0表示正常終止 Bytes_received/sent:收到和發(fā)送的字節(jié)數(shù)Read_last:讀取索引最后一個(gè)key的次數(shù) Read_key:基于key讀取行的請(qǐng)求數(shù),較大說明使用正確的索Sort_range_count:使用范圍完成的排序次數(shù) Sort_rows:排序的行數(shù)Sort_scan_count:通過掃描表完成的排序次數(shù);Start/End:語句開始和結(jié)束Read_next:按順序取下一行數(shù)據(jù)的次數(shù),索引范圍查找和索引掃描時(shí)該值Read_prev:按順序讀取上一行的請(qǐng)求數(shù),orderbydesc查詢較優(yōu)時(shí)該值較Read_first:讀取索引中第一條數(shù)據(jù)的記錄,該值反映全索引掃Read_rnd:按固定位置讀取行的請(qǐng)求數(shù),大量的回表、沒有索引的連接和對(duì)結(jié)果集排序時(shí)Read_rnd_next:讀取數(shù)據(jù)文件下一行的次數(shù),大量表掃描、未創(chuàng)建或合理使用索引時(shí)Sort_merge_passes:排序算法合并的次數(shù),如該值較大考慮增加sort_buffer_size的Created_tmp_disk_tables:創(chuàng)建內(nèi)部磁盤臨時(shí)Created_tmp_tables:創(chuàng)建內(nèi)部臨時(shí)使用工具分析慢查詢mysqldumpslow,mysql自帶慢查詢-r-n只顯示前n個(gè)-a不對(duì)數(shù)字和字符串進(jìn)-g字符串-al平均鎖等待時(shí)間at平均查詢時(shí)間arc出現(xiàn)總l等待鎖的時(shí)間r返回總t累計(jì)查詢耗時(shí)pt-query-econatookt中的工具可以從普通日志、慢查詢?nèi)罩?、二進(jìn)日志以及howpocet和tcpup中對(duì)SL進(jìn)行分析;默認(rèn)type分析慢查詢query-/data/mysql/data/node1-輸;包括總的查詢次數(shù)、Profile:對(duì)重要或較慢查詢進(jìn)Rank:Responsetime“語句”的響應(yīng)時(shí)間Calls該“語句”的執(zhí)R/Call每次執(zhí)行的平均響應(yīng)時(shí)間V/M響應(yīng)時(shí)間的方差均值比(VMR)(值越大這類SQL響應(yīng)時(shí)間越趨于不同)詳細(xì)信息:Profile中各SQL的詳細(xì)信息,默認(rèn)按總ExecTime降序輸pt-query-digest:提供較type:指定輸入文件的類型,默認(rèn)是slowlog輸入是MySQL慢查詢binlog輸入是mysqlbinlog轉(zhuǎn)換后的二進(jìn)genlog輸入是MySQLgeneraltcpdump分析tcpdump抓包內(nèi)容,建議以-x-n-q-tttt格式化抓包輸rawlog輸入不是MySQL日志,而是換行分隔的SQL語Group-by:指定分類的屬性,默認(rèn)是order-by:指定排序方式,默認(rèn)是Query_time:sum。聚合方式包括sum、min、max、Sysschema:MySQL5.7開始支持,由表、視圖、存儲(chǔ)過程和函數(shù)等一系列對(duì)象組成,本身不存儲(chǔ),而是將performance_schema和information_schema中的數(shù)據(jù)已更容易理解的形式組織和呈現(xiàn)調(diào)優(yōu)和診斷。sysschema的對(duì)將性能模式數(shù)據(jù)匯總為更易于理解的形式的視圖執(zhí)行諸如PerformanceSchema配置和生成診斷報(bào)告之類的操作的存儲(chǔ)過查詢PerformanceSchema配置并提供格式化服務(wù)的存儲(chǔ)由于sysschema提供的是performanceschema的另一種訪問方式,要使用sysschema需要啟用performanceschema;【performance_schema=ON】必須啟用某些performanceschema的instruments和consumers后才能充分利用sysCALLCALLCALLCALLCALL啟用上述instruments和consumers會(huì)對(duì)性能造成影響,可快速恢復(fù)默CALL通過以下SQL啟用全部的instrumentsandUPDATEperformance_schema.setup_consumersSETENABLED=UPDATEperformance_schema.setup_instrumentsSETENABLED='YES',TIMED=Sysschema中包含兩類對(duì)象,以x$開頭的視圖返回原始數(shù)據(jù),其余視圖返回的是經(jīng)過轉(zhuǎn)換后跟容易理Sysschema中對(duì)象有以下幾主機(jī)相關(guān),host_summary開頭的Innodb相關(guān),以innodb開頭的視圖(慎用IO使用情況,以IO開頭的內(nèi)存使用情況,以memory開頭的連接與會(huì)話信息,含有processlist和session的表相關(guān)信息,以schema_table開頭的索引相關(guān)信息,含有index的語句相關(guān)信息,以statement開頭的用戶相關(guān)信息,以u(píng)ser開頭的時(shí)間等待相關(guān)信息,以wait開頭的schema_table_statistics視圖查看table的增刪查改以及IOschema_tables_with_full_table_scans視圖查看全表掃描情況,可作為優(yōu)schema_auto_increment_columns視圖查看自增主鍵schema_index_statistics視圖查看索引的增刪改查schema_redundant_indexes和schema_unused_indexes視圖分別查statements_with_full_table_scans視圖查看全表掃描的SQLstatement_analysis視圖查看SQL匯總統(tǒng)計(jì)信息(數(shù)據(jù)來源statements_with_errors_or_warnings視圖查看出現(xiàn)error和warning的statements_with_sorting和statements_with_temp_tables視圖查看使用排序和臨時(shí)表的statements_with_runtimes_in_95th_percentile視圖查看runtime在95%的SQL,視圖數(shù)據(jù)默認(rèn)avg_latency我們通過視圖statement_analysis查看總執(zhí)行時(shí)間最長的SQL:select*fromsys.statement_analysisorderbytotal_latencydesclimit1\Gquery:抽象后的Db:語句默認(rèn)數(shù)據(jù)full_scan:全表掃描的話*,否則total/max/avg/lock_latency:總時(shí)間、最大時(shí)間、平均時(shí)間、總鎖等待rows_sent/rows_sent_avg:總rows_examined/rows_examined_avg:總檢查行數(shù)、平均檢查tmp_tables:創(chuàng)建臨時(shí)exec_count:執(zhí)err_count/warn_count:錯(cuò)誤tmp_disk_tables:創(chuàng)建磁盤臨時(shí)rows_sortedsort_merge_passes查看innodb_buffer_page相關(guān)視圖會(huì)導(dǎo)致innodbbufferpool的掃描,非常影響性能,不要在生產(chǎn)環(huán)境訪開啟performanceschema采集指標(biāo)信息會(huì)對(duì)性能造成一定影響,請(qǐng)謹(jǐn)慎選擇;(特別是打開所有02MySQL怎么訪問連接查詢FileFileHeader38字頁號(hào)、checksum、上下頁號(hào)、LSNPageHeader56字節(jié)記錄數(shù)、freespace位置等SystemRecord26字Infimum+Supremum兩個(gè)虛擬UserRecordUn-rdrd存儲(chǔ)的行記錄數(shù)據(jù),每行數(shù)據(jù)包含nxtrrd指針,指向頁升序的單向鏈表FreeSpace頁面中還沒有使用的空閑空PageDirectory頁面中某些記錄的相對(duì)位置,方便二分查FileTrailer8字節(jié)checksum和fileheader結(jié)構(gòu)中的上下文頁號(hào)組成雙向鏈。每個(gè)page中還維護(hù)了一個(gè)pagedirectoryInnodb作為索引組織表,所有數(shù)據(jù)存儲(chǔ)在聚簇索引(primarykey)這個(gè)二級(jí)索引(secondarykey)使用索引列的大小進(jìn)行記錄和頁的排序,葉子全表掃描ALL,依次掃描表中所有記錄,將符合條件的數(shù)據(jù)加入結(jié)使用索引Const:通過主鍵或唯一索引定位一條記錄,主鍵或唯一索引的等Ref:非唯一索引的等值查詢;可能會(huì)匹配到多條在二級(jí)索引中連續(xù)的Range:利用索引進(jìn)行范圍查詢;包括多個(gè)單點(diǎn)區(qū)間和連續(xù)的范圍區(qū)Index:全索引掃描,通過遍歷索引得到結(jié)特殊情況下可以在一個(gè)查詢中使用多個(gè)二級(jí)索引,稱為index系統(tǒng)變量optimizer_switch中index_merge=on,或者index_merge=off并單獨(dú)打開、index_merge_sort_union、index_merge_intersectionindexmergeintersection:交集合并。當(dāng)查詢條件是多個(gè)二級(jí)索引等值匹配,主鍵可以是范圍匹配indexmergeunion:并集合并。當(dāng)查詢條件是多個(gè)二級(jí)索引等值匹配,主鍵可以是范圍(or)條件時(shí)indexmergesortunion:排序并集合并。當(dāng)查詢條件是多個(gè)二級(jí)索引的范圍匹配,且從某個(gè)二級(jí)索連接查詢本質(zhì)上就是將各個(gè)表中的數(shù)據(jù)依次匹配后加入結(jié)果集中并返回,不帶任何條件時(shí)結(jié)果集包含每一個(gè)表中所有與其他表所有記錄的組合,稱為笛卡爾積,連接分為內(nèi)連接和外連MySQL之前默認(rèn)的連接方式為嵌套循環(huán)連接(nested-loopjoin)從8.0.18開始支持對(duì)等值條件的連接查詢使用hash,從8.0.20開始使用hashjoinBlockNested-LoopJoin,并且hashjoin開始支持外連對(duì)于nested-loopjoin嵌套循環(huán)連接,首先選擇驅(qū)動(dòng)表,通過驅(qū)動(dòng)表的過濾條件得到結(jié)果集。再用結(jié)果集中每一條記錄,為了優(yōu)化傳統(tǒng)的嵌套循環(huán)連接,減少被驅(qū)動(dòng)表的訪問次數(shù),MySQL提供了基于塊的嵌套循環(huán)連接方式(BlockNested-LoopJoin)進(jìn)行優(yōu)化。該方法會(huì)將驅(qū)動(dòng)表過濾后的結(jié)果集以及查詢需要的列存入joinbuffer這一內(nèi)存結(jié)構(gòu)中,再將join(Build)和探測(Probe)兩個(gè)階段;構(gòu)建時(shí)MySQL選擇空間較小的表,對(duì)關(guān)聯(lián)字段hash計(jì)算后存入joinbuffer中。hashjoin時(shí)joinbuffer測階段會(huì)對(duì)另一張表的關(guān)聯(lián)字段hash計(jì)算后,與joinbuffer中的hashtable進(jìn)行匹配。匹配成功后返回結(jié)果。當(dāng)joinbuffer無法容納整個(gè)hashtable時(shí),會(huì)將兩個(gè)表的數(shù)據(jù)分別溢出到塊文件中,再對(duì)每一對(duì)塊文件做hash匹配并返回結(jié)果。如果表數(shù)據(jù)較joinbuffer較少時(shí),要注意open_files_limit的限制;優(yōu)常量傳遞。constant_propagation,x=5andx>yx=5and等值傳遞。equality_propagation,x=yandy=zandx=42x=42andy=42and移除不用的條件。trivial_condition_removal,removeconditionsthatarealwaysfalseoralways表達(dá)式計(jì)算。x=5+1x=6,注意索引列不能在函數(shù)中,例如having和where子句的合并。如查詢沒有sum,max等聚合函數(shù)以及groupby子句,優(yōu)化器將having和where常量表檢測。當(dāng)表中沒有數(shù)據(jù)或者通過主鍵和唯一索引等值匹配時(shí),優(yōu)化器會(huì)首先執(zhí)行constanttable查詢,并將條外連接消除。當(dāng)出現(xiàn)null-rejecting也就是被驅(qū)動(dòng)表在where子句中包含不為null的條件時(shí),外連接和內(nèi)連接和相互子查詢優(yōu)化:某些符合條件的in子查詢MySQL會(huì)優(yōu)化成成semi-join的方式執(zhí)IO成本:將數(shù)據(jù)從磁盤加載到內(nèi)存的開銷,讀取一個(gè)頁面的成本默認(rèn)CPU成本:條件判斷或排序等操作的開銷,檢測一條記錄的成本默認(rèn)成本常數(shù)存放在mysql.server_cost和mysql.engine_cost中,可以修改cost_value值后執(zhí)行flushoptimizer_costs加維護(hù)當(dāng)前最小成本變量,提前結(jié)束成本評(píng)系統(tǒng)變量optimizer_search_depth,決定參與評(píng)估的連接表個(gè)數(shù)。默認(rèn)系統(tǒng)變量optimizer_prune_level,開啟啟發(fā)式規(guī)則。默認(rèn)開啟。開啟后優(yōu)化器會(huì)對(duì)各表訪問預(yù)估跳過引的頁面統(tǒng)計(jì)計(jì)算出來的。我們可以通過showtablestatusshowindex查看到表的預(yù)估的行數(shù),索引中唯一值的數(shù)量也持久化存儲(chǔ)的統(tǒng)計(jì)信息是存放在mysql庫統(tǒng)計(jì)信息可以自動(dòng)或手動(dòng)的方式采集,如果系統(tǒng)變量nnob_tat_auto_ecac設(shè)置為N(默認(rèn)值),則當(dāng)表中數(shù)據(jù)變動(dòng)超過10%時(shí)MySL將異步更新該表的統(tǒng)計(jì)信息。否則只能通過anayetae的方式手動(dòng)更新。由于數(shù)據(jù)庫的統(tǒng)計(jì)信息是按表來采集和存儲(chǔ)的,所以也可以在建表時(shí)通過tat_auto_ecac=1指定。注意:在MySQL中執(zhí)行analyzetable時(shí),如果該表有長事務(wù),將會(huì)阻塞其他事務(wù)對(duì)該innodb_index_stats和innodb_table_stats表中的統(tǒng)計(jì)數(shù)據(jù)也可以手動(dòng)修改,只是修改后需執(zhí)行flushtable查看執(zhí)行計(jì)劃及optimizertraceMySQL提供Explain工具查看某個(gè)SQL的執(zhí)行計(jì)劃,SQL并不會(huì)真正執(zhí)行。在只讀實(shí)例上無法查看寫入SQL的執(zhí)行Explain[format=(triditional|tree|json)]Id:操作表順序。id從大到小執(zhí)行,id相同從上到下執(zhí)select_type:查詢類型。(smiple/primary/union/subquery/dependentType:查詢數(shù)據(jù)的具體訪問方式possible_key&key:可能用到的和實(shí)際選擇key_len:使用索引的長度(組合索引的一部分Ref:使用索引列做等值匹配時(shí)Row:預(yù)計(jì)掃描的行數(shù)或索引記錄Filtered:掃描的行數(shù)中符合其他條件的比例。下圖sbtest7主鍵掃描19774條記錄中,預(yù)估11.11%滿Extra:其他關(guān)鍵信息(usingwhere/usingfilesort/usingindex/using查詢類型simple:不包括union或子Primary:包含union或子查詢的最外union:子查詢中除了primary的Unionresult:使用臨時(shí)表對(duì)union結(jié)subquery:不能轉(zhuǎn)換成semi-join的不相關(guān)子dependentsubquery:不能轉(zhuǎn)換成semi-join的相關(guān)子Derived:采用物化的方式執(zhí)行的Materialized:子查詢物化后與外層進(jìn)行連接數(shù)據(jù)掃描方式Const:使用主鍵或唯一索引等eq_ref:連接查詢被驅(qū)動(dòng)表通過主鍵或唯一索引等值Ref:非唯一索引等值range:范Index:覆蓋索引掃ALL:全表掃usingfilesortusingtemptemporary:使用臨時(shí)usingwhereusingindex:覆蓋索引掃M(jìn)ySQL8.0.18開始支持Explainanalyze,Explainanalyze按format=tree格式輸出,除了返回預(yù)估的成本和行SQL,在8.0.20以后可以通過killquery或CTRL-C終止運(yùn)行。hashjoin用法只能由TREE格式顯示,所以Explainanalyze也可以顯示查詢是否使用hashjoin。MySQL提供optimizertrace工具剖析SQL

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論