佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 關于MySQL中的查詢開銷查看方法詳解

關于MySQL中的查詢開銷查看方法詳解

熱門標簽:Linux服務器 網(wǎng)站排名優(yōu)化 服務外包 地方門戶網(wǎng)站 鐵路電話系統(tǒng) AI電銷 呼叫中心市場需求 百度競價排名

MySQL邏輯架構(gòu)

如果能在頭腦中構(gòu)建一幅MySQL各組件之間如何協(xié)同工作的架構(gòu)圖,有助于深入理解MySQL服務器。下圖展示了MySQL的邏輯架構(gòu)圖。

MySQL邏輯架構(gòu),來自:高性能MySQL

MySQL邏輯架構(gòu)整體分為三層,最上層為客戶端層,并非MySQL所獨有,諸如:連接處理、授權認證、安全等功能均在這一層處理。

MySQL大多數(shù)核心服務均在中間這一層,包括查詢解析、分析、優(yōu)化、緩存、內(nèi)置函數(shù)(比如:時間、數(shù)學、加密等函數(shù))。所有的跨存儲引擎的功能也在這一層實現(xiàn):存儲過程、觸發(fā)器、視圖等。

最下層為存儲引擎,其負責MySQL中的數(shù)據(jù)存儲和提取。和Linux下的文件系統(tǒng)類似,每種存儲引擎都有其優(yōu)勢和劣勢。中間的服務層通過API與存儲引擎通信,這些API接口屏蔽了不同存儲引擎間的差異。

MySQL使用基于成本的優(yōu)化器,它嘗試預測一個查詢使用某種執(zhí)行計劃時的成本,并選擇其中成本最小的一個。在MySQL可以通過查詢當前會話的last_query_cost的值來得到其計算當前查詢的成本。

示例代碼

mysql> select * from t_message limit 10;
...省略結(jié)果集

mysql> show status like 'last_query_cost';
+-----------------+-------------+
| Variable_name | Value |
+-----------------+-------------+
| Last_query_cost | 6391.799000 |
+-----------------+-------------+

示例中的結(jié)果表示優(yōu)化器認為大概需要做6391個數(shù)據(jù)頁的隨機查找才能完成上面的查詢。這個結(jié)果是根據(jù)一些列的統(tǒng)計信息計算得來的,這些統(tǒng)計信息包括:每張表或者索引的頁面?zhèn)€數(shù)、索引的基數(shù)、索引和數(shù)據(jù)行的長度、索引的分布情況等等。

有非常多的原因會導致MySQL選擇錯誤的執(zhí)行計劃,比如統(tǒng)計信息不準確、不會考慮不受其控制的操作成本(用戶自定義函數(shù)、存儲過程)、MySQL認為的最優(yōu)跟我們想的不一樣(我們希望執(zhí)行時間盡可能短,但MySQL值選擇它認為成本小的,但成本小并不意味著執(zhí)行時間短)等等。

這里last_query_cost的值是io_cost和cpu_cost的開銷總和,它通常也是我們評價一個查詢的執(zhí)行效率的一個常用指標。

(1)它是作為比較各個查詢之間的開銷的一個依據(jù)。

(2)它只能檢測比較簡單的查詢開銷,對于包含子查詢和union的查詢是測試不出來的。

(3)當我們執(zhí)行查詢的時候,MySQL會自動生成一個執(zhí)行計劃,也就是query  plan,而且通常有很多種不同的實現(xiàn)方式,它會選擇最低的那一個,而這個cost值就是開銷最低的那一個。

(4)它對于比較我們的開銷是非常有用的,特別是我們有好幾種查詢方式可選的時候。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • mysql中模糊查詢的四種用法介紹
  • 解析mysql中:單表distinct、多表group by查詢?nèi)コ貜陀涗?/li>
  • Mysql聯(lián)合查詢UNION和UNION ALL的使用介紹
  • MySQL查詢in操作 查詢結(jié)果按in集合順序顯示
  • MySql查詢時間段的方法
  • MySQL中基本的多表連接查詢教程
  • mysql分頁原理和高效率的mysql分頁查詢語句
  • MySQL里面的子查詢實例
  • mysql show processlist 顯示mysql查詢進程
  • MySQL查詢本周、上周、本月、上個月份數(shù)據(jù)的sql代碼

標簽:湖南 蘭州 銅川 衡水 崇左 湘潭 仙桃 黃山

巨人網(wǎng)絡通訊聲明:本文標題《關于MySQL中的查詢開銷查看方法詳解》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    邵阳市| 平潭县| 阿勒泰市| 平山县| 抚宁县| 昌乐县| 静安区| 宝丰县| 南康市| 鄂托克旗| 澜沧| 县级市| 温泉县| 福泉市| 惠州市| 白银市| 金华市| 乐山市| 乌什县| 沁水县| 漳平市| 广昌县| 临武县| 遂平县| 汉寿县| 象州县| 邻水| 长岛县| 禹州市| 姜堰市| 崇文区| 新和县| 宣恩县| 定西市| 靖安县| 如皋市| 宁强县| 秦皇岛市| 大余县| 邻水| 黎平县|