日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > > 架構(gòu)師社區(qū)
[導(dǎo)讀]本篇文章詳細(xì)講解了Optimizer Trace展示的所有相關(guān)信息,并且輔之一些具體使用案例。


在上一篇文章《用Explain 命令分析 MySQL 的 SQL 執(zhí)行》中,我們講解了 Explain 命令的詳細(xì)使用。但是它只能展示 SQL 語(yǔ)句的執(zhí)行計(jì)劃,無法展示為什么一些其他的執(zhí)行計(jì)劃未被選擇,比如說明明有索引,但是為什么查詢時(shí)未使用索引等。為此,MySQL 提供了 Optimizer Trace 功能,讓我們能更加詳細(xì)的了解 SQL 語(yǔ)句執(zhí)行的所有分析,優(yōu)化和選擇過程。

如果您想更深入地了解為什么選擇某個(gè)查詢計(jì)劃,那么優(yōu)化器跟蹤非常有用。雖然 EXPLAIN 顯示選定的計(jì)劃,但Optimizer Trace 能顯示為什么選擇計(jì)劃:您將能夠看到替代計(jì)劃,估計(jì)成本以及做出的決策。本篇文章會(huì)詳細(xì)講解 Optimizer Trace 展示的所有相關(guān)信息,并且會(huì)輔之一些具體使用案例。

基于成本的執(zhí)行計(jì)劃

在了解 Optimizer Trace 的之前,我們先來學(xué)習(xí)一下 MySQL 是如何選擇眾多執(zhí)行計(jì)劃的。

MySQL 會(huì)使用一個(gè)基于成本(cost)的優(yōu)化器對(duì)執(zhí)行計(jì)劃進(jìn)行選擇。每個(gè)執(zhí)行計(jì)劃的成本大致反應(yīng)了該計(jì)劃查詢所需要的資源,主要因素是計(jì)算查詢時(shí)將要訪問的行數(shù)。優(yōu)化器主要根據(jù)從存儲(chǔ)引擎獲取數(shù)據(jù)的統(tǒng)計(jì)數(shù)據(jù)和數(shù)據(jù)字典中元數(shù)據(jù)信息來做出判斷。它會(huì)決定是使用全表掃描或者使用某一個(gè)索引進(jìn)行掃描,也會(huì)決定表 join的順序。優(yōu)化器的作用如下圖所示。

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

優(yōu)化器會(huì)為每個(gè)操作標(biāo)上成本,這些成本的基準(zhǔn)單位或最小值是從磁盤讀取隨機(jī)數(shù)據(jù)頁(yè)的成本,其他操作的成本都是它的倍數(shù)。所以優(yōu)化器可以根據(jù)每個(gè)執(zhí)行計(jì)劃的所有操作為其計(jì)算出總的成本,然后從眾多執(zhí)行計(jì)劃中,選取成本最小的來最終執(zhí)行。

既然是基于統(tǒng)計(jì)數(shù)據(jù)來進(jìn)行標(biāo)記成本,就總會(huì)有樣本無法正確反映整體的情況,這也是 MySQL 優(yōu)化器有時(shí)做出錯(cuò)誤優(yōu)化的重要原因之一。

Optimizer Trace 的基本使用

首先,我們來看一下具體如何使用 Optimizer Trace。默認(rèn)情況下,該功能是關(guān)閉的,大家可以使用如下方式打開該功能,然后執(zhí)行自己需要分析的 SQL 語(yǔ)句,然后再?gòu)?INFORMATIONSCHEMA 的 OPTIMIZERTRACE中查找到該 SQL 語(yǔ)句執(zhí)行優(yōu)化的相關(guān)信息。

   
  1. # 1. 打開optimizer trace功能 (默認(rèn)情況下它是關(guān)閉的):

  2. SET optimizer_trace="enabled=on";

  3. SELECT ...; # 這里輸入你自己的查詢語(yǔ)句

  4. SELECT * FROM INFORMATION_SCHEMA.OPTIMIZER_TRACE;

  5. # 當(dāng)你停止查看語(yǔ)句的優(yōu)化過程時(shí),把optimizer trace功能關(guān)閉

  6. SET optimizer_trace="enabled=off";

這個(gè) OPTIMIZER_TRACE 表有4個(gè)列,如下所示:

  • QUERY:表示我們的查詢語(yǔ)句。

  • TRACE:表示優(yōu)化過程的JSON格式文本。

  • MISSING_BYTES_BEYOND_MAX_MEM_SIZE:由于優(yōu)化過程可能會(huì)輸出很多,如果超過某個(gè)限制時(shí),多余的文本將不會(huì)被顯示,這個(gè)字段展示了被忽略的文本字節(jié)數(shù)。

  • INSUFFICIENT_PRIVILEGES:表示是否沒有權(quán)限查看優(yōu)化過程,默認(rèn)值是0,只有某些特殊情況下才會(huì)是?1,我們暫時(shí)不關(guān)心這個(gè)字段的值。

其中,信息最多也最為重要的就是第二列 TRACE,它也是我們后續(xù)分析的重點(diǎn)。

TRACE 列的基本格式

TRACE 列的內(nèi)容是一個(gè)超級(jí)大的 JSON 數(shù)據(jù),直接展開然后一條一條解析估計(jì)能看到大伙腦殼疼。

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

所以,我們先來看一下這坨大 JSON 的骨架。它有三大塊內(nèi)容,也代表著 SQL 語(yǔ)句處理的三個(gè)階段,分別為準(zhǔn)備階段,優(yōu)化階段和執(zhí)行階段。

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

接下來,我們?cè)敿?xì)介紹一個(gè)案例,在案例中介紹涉及到的具體字段和含義。

為什么查詢未走索引而是全表掃描

首先,SQL 語(yǔ)句查詢不使用索引的情況有很多,我們這里只討論因?yàn)榛诔杀镜膬?yōu)化器認(rèn)為全表查詢執(zhí)行計(jì)劃的成本低于走索引執(zhí)行計(jì)劃的情況。

如下圖這個(gè)場(chǎng)景,明明 val 列上有索引,并且 val 現(xiàn)存值也有一定差異性,為什么沒有使用索引進(jìn)行查詢呢?

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

我們按照上文使用 Optimizer Trace 找到其 joinoptimization 中 rangeanalysis 相關(guān)數(shù)據(jù),它會(huì)展示 where 從句范圍查詢過程中索引的選擇情況

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

由上圖可以看出,MySQL 對(duì)比了全表掃描和使用 val 作為索引兩個(gè)方案的成本,最后發(fā)現(xiàn)雖然全表掃描需要掃描更多的行,但是成本更低。所以選擇了全表掃描的執(zhí)行方案。

這是為什么呢?明明使用 val 索引可以少掃描 4 行。這其實(shí)涉及 InnoDB 中使用索引查詢數(shù)據(jù)行的原理。

Innodb引擎查詢記錄時(shí)在無法使用索引覆蓋(也就是需要查詢的數(shù)據(jù)多與索引值,比如該例子中,我要查name,而索引列是 val)的場(chǎng)景下,需要做回表操作獲取記錄的所需字段,也就是說,通過索引查出主鍵,再去查數(shù)據(jù)行,取出對(duì)應(yīng)的列,這樣勢(shì)必是會(huì)多花費(fèi)成本的。

所以在回表數(shù)據(jù)量比較大時(shí),經(jīng)常會(huì)出現(xiàn) Mysql 對(duì)回表操作查詢代價(jià)預(yù)估代價(jià)過大而導(dǎo)致不使用索引的情況。

一般來說,當(dāng)SQL 語(yǔ)句查詢超過表中超過大概五分之一的記錄且不能使用覆蓋索引時(shí),會(huì)出現(xiàn)索引的回表代價(jià)太大而選擇全表掃描的現(xiàn)象。且這個(gè)比例隨著單行記錄的字節(jié)大小的增加而略微增大。

通過 range_analysis 中的相關(guān)數(shù)據(jù)也可以對(duì) where 從句使用多個(gè)索引列,如何選擇執(zhí)行時(shí)使用的索引的情況進(jìn)行分析。

小節(jié)

終于,介紹了有關(guān)于 MySQL 語(yǔ)句執(zhí)行分析的 explain 和 Optimizer Trace,下一篇,我們將分析具體的死鎖場(chǎng)景。

特別推薦一個(gè)分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長(zhǎng)按關(guān)注一下:

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

長(zhǎng)按訂閱更多精彩▼

100%展示MySQL語(yǔ)句執(zhí)行的神器-Optimizer Trace

如有收獲,點(diǎn)個(gè)在看,誠(chéng)摯感謝


免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉