欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文搞懂MySQL運行機制原理

 更新時間:2022年09月30日 08:35:30   作者:1個俗人???????  
這篇文章主要介紹了一文搞懂MySQL運行機制原理,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

前言

前文我們了解了MySQL采用客戶端/服務器架構,用戶通過客戶端程序發(fā)送增刪改查需求,服務器程序收到請求后處理,并且把處理結(jié)果返回給客戶端。這篇文章主要看下MySQL服務端是如何處理客戶端的請求,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

MySQL服務器體系架構

MySQL Server架構自頂向下大致可以分網(wǎng)絡連接層、服務層、存儲引擎層和系統(tǒng)文件層。

網(wǎng)絡連接層

客戶端連接器:提供與MySQL服務器建立的支持。

服務層

主要包含系統(tǒng)管理和控制工具、連接池、SQL接口、解析器、查詢優(yōu)化器和緩存六個部分。

  • 1) 連接池:存儲和管理客戶端與數(shù)據(jù)庫的連接。
  • 2) 系統(tǒng)管理和控制工具:集群、備份、安全管理。
  • 3) SQL接口:接受客戶端發(fā)送的各種SQL命令并返回查詢結(jié)果。
  • 4) 解析器:解析SQL,生成一顆解析樹,驗證SQL是否合法。
  • 5) 查詢優(yōu)化器:將解析樹轉(zhuǎn)化成執(zhí)行計劃,與存儲引擎進行交互。
  • 6) 緩存:各種緩存,比如表、記錄、權限等等,緩存有命中查詢結(jié)果直接返回。

存儲引擎層

負責MySQL中數(shù)據(jù)的存儲與提取,與底層系統(tǒng)文件進行交互,可插拔,常見的兩類:MyISAM和InnoDB。

系統(tǒng)文件層

負責將數(shù)據(jù)庫的數(shù)據(jù)和日志存儲在文件系統(tǒng)之上,并完成與存儲引擎的交互,比如日志、配置文件等等。

服務器處理客戶端請求

客戶端可以向服務器發(fā)送增刪改查等各類請求,我們來看一下服務器是如何處理客戶端發(fā)送的請求。

連接管理

客戶端與服務器進程建立連接,每當有一個客戶端進程連接到服務器進程時,服務器進程都會創(chuàng)建一個線程來專門處理與這個客戶端的交互,當該客戶端退出時會與服務器斷開連接,服務器會把線程緩存起來。

解析與優(yōu)化

查詢緩存

如果兩個查詢請求在任何字符上的不同都會導致緩存不命中。請求中包含某些系統(tǒng)函數(shù)、用戶自定義變量和函數(shù)、一些系統(tǒng)表也不會被緩存。

只要該表的結(jié)構或者數(shù)據(jù)被修改,則該表的所有高速緩存查詢都將無效并刪除。

PS:8.0中查詢緩存已經(jīng)刪除了

語法解析

如果查詢緩存沒有命中,就進入查詢階段,服務器先對文本做分析,判斷語法是否正確,然后從文本中將要查詢的表、各種查詢條件都提取出來放到內(nèi)部使用的一些數(shù)據(jù)結(jié)構上。

算是一個編譯過程,涉及詞法解析、語法分析、語義分析等階段。

查詢優(yōu)化

對SQL做優(yōu)化,生成一個執(zhí)行計劃,表明了應該使用哪些索引進行查詢,表之間的連接順序是怎樣的。

我們可以使用Explain來查看某個語句的執(zhí)行計劃。

存儲引擎

完成查詢優(yōu)化之后還沒有真正去訪問真實的數(shù)據(jù)表,數(shù)據(jù)的存儲和提取操作都封裝到了這個模塊里。不同存儲引擎管理的表具體的存儲結(jié)構可能不同,采用存取算法也可能不同。

小結(jié)

MySQL Server架構自頂向下大致可以分網(wǎng)絡連接層、服務層、存儲引擎層和系統(tǒng)文件層。mysql執(zhí)行查詢的過程如下:

  • 客戶端先發(fā)送查詢語句給服務器
  • 服務器檢查緩存,如果存在則返回
  • 進行sql解析,生成解析樹,再預處理,生成第二個解析樹,最后再經(jīng)過優(yōu)化器,生成真正的執(zhí)行計劃
  • 根據(jù)執(zhí)行計劃,調(diào)用存儲引擎的API來執(zhí)行查詢
  • 將結(jié)果返回給客戶端。

到此這篇關于一文搞懂MySQL運行機制原理的文章就介紹到這了,更多相關MySQL運行機制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MYSQL開發(fā)性能研究之批量插入數(shù)據(jù)的優(yōu)化方法

    MYSQL開發(fā)性能研究之批量插入數(shù)據(jù)的優(yōu)化方法

    在網(wǎng)上也看到過另外的幾種方法,比如說預處理SQL,比如說批量提交。那么這些方法的性能到底如何?本文就會對這些方法做一個比較
    2017-07-07
  • MySQL使用LIKE索引是否失效的驗證的示例

    MySQL使用LIKE索引是否失效的驗證的示例

    LIKE查詢可以通過一些方法來使得LIKE查詢能夠使用索引,本文主要介紹了MySQL使用LIKE索引是否失效的驗證的示例,具有一定的參考價值,感興趣的可以了解一下
    2024-08-08
  • MySQL 行轉(zhuǎn)列詳情

    MySQL 行轉(zhuǎn)列詳情

    這篇文章主要介紹了MySQL 行轉(zhuǎn)列詳情,MySQL 行轉(zhuǎn)列語句不難,具體的詳細資料,感興趣的小伙伴可以參考一下
    2022-01-01
  • MySQL分庫分表后路由策略設計詳情

    MySQL分庫分表后路由策略設計詳情

    這篇文章主要介紹了MySQL分庫分表后路由策略設計詳情,分庫分表后設計到的第一個問題就是,如何選擇路由key,應該如何對key進行路由
    2022-08-08
  • 教你使用idea連接服務器mysql的步驟

    教你使用idea連接服務器mysql的步驟

    這篇文章主要介紹了如何使用idea連接服務器上的mysql,具體步驟本文給大家介紹的非常詳細,需要的朋友可以參考下
    2024-02-02
  • 在SQL中獲取一個長字符串中某個字符串出現(xiàn)次數(shù)的實現(xiàn)方法

    在SQL中獲取一個長字符串中某個字符串出現(xiàn)次數(shù)的實現(xiàn)方法

    以下是對在SQL中獲取一個長字符串中某個字符串出現(xiàn)次數(shù)的實現(xiàn)方法進行了詳細的分析介紹,需要的朋友可以參考下
    2013-07-07
  • mysql數(shù)據(jù)庫太大了如何備份與還原

    mysql數(shù)據(jù)庫太大了如何備份與還原

    今天小編就為大家分享一篇關于mysql數(shù)據(jù)庫太大了如何備份與還原,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • mysql數(shù)據(jù)庫查詢優(yōu)化 mysql效率

    mysql數(shù)據(jù)庫查詢優(yōu)化 mysql效率

    MySQL由于它本身的小巧和操作的高效, 在數(shù)據(jù)庫應用中越來越多的被采用.我在開發(fā)一個P2P應用的時候曾經(jīng)使用MySQL來保存P2P節(jié)點,由于P2P的應用中,結(jié)點數(shù)動輒上萬個,而且節(jié)點變化頻繁,因此一定要保持查詢和插入的高效.以下是我在使用過程中做的提高效率的三個有效的嘗試. 1. 使用statement進行綁定查詢 2. 隨機的獲取記錄 3. 使用連接池管理連接.
    2008-01-01
  • mysql 5.0.45 (修改)拒絕服務漏洞

    mysql 5.0.45 (修改)拒絕服務漏洞

    mysql 5.0.45 (修改)拒絕服務漏洞的方法,追求安全的朋友可以參考下。
    2010-07-07
  • 安裝的mysql中沒有my.ini文件的解決方法

    安裝的mysql中沒有my.ini文件的解決方法

    本文主要介紹了安裝的mysql中沒有my.ini文件的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03

最新評論