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

MySQL通透詳解架構(gòu)設(shè)計(jì)

 更新時(shí)間:2022年02月07日 15:33:00   作者:JavaEdge.  
這篇文章主要介紹了MySQL架構(gòu)設(shè)計(jì)相關(guān)基礎(chǔ)與原則,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下

系統(tǒng)只要能從數(shù)據(jù)庫連接池獲取到一個(gè)數(shù)據(jù)庫連接,就能執(zhí)行CRUD??赏ㄟ^數(shù)據(jù)庫連接將待執(zhí)行SQL發(fā)給MySQL。

大部分 crud boy只知道:

  • 執(zhí)行insert語句后,在表里會(huì)多條數(shù)據(jù)
  • 執(zhí)行update后,會(huì)更改表數(shù)據(jù)
  • 執(zhí)行delete后,會(huì)刪除表里數(shù)據(jù)
  • 執(zhí)行select后,會(huì)查詢表里數(shù)據(jù)出來
  • 要是SQL性能丟人,建幾個(gè)索引解決

這應(yīng)該是目前行業(yè)內(nèi)很多工程師對(duì)數(shù)據(jù)庫的一個(gè)認(rèn)知,完全當(dāng)他是個(gè)黑盒來建表及執(zhí)行SQL。

網(wǎng)絡(luò)連接必須有線程處理

假設(shè)數(shù)據(jù)庫服務(wù)器的連接池中的某個(gè)連接,接收到一條SQL網(wǎng)絡(luò)請(qǐng)求,請(qǐng)思考:

  • 誰負(fù)責(zé)從這個(gè)連接中去監(jiān)聽網(wǎng)絡(luò)請(qǐng)求?
  • 誰負(fù)責(zé)從網(wǎng)絡(luò)連接里把請(qǐng)求數(shù)據(jù)讀取出來?

網(wǎng)絡(luò)連接得有一個(gè)線程來監(jiān)聽請(qǐng)求及讀取請(qǐng)求數(shù)據(jù),比如從網(wǎng)絡(luò)連接中讀取和解析出來一條業(yè)務(wù)系統(tǒng)發(fā)的SQL語句:

img

SQL接口

負(fù)責(zé)處理接收到的SQL語句。

MySQL的工作線程從一個(gè)網(wǎng)絡(luò)連接中讀出一個(gè)SQL語句后,會(huì)如何執(zhí)行該SQL呢?

MySQL提供了SQL接口(SQL Interface),一套執(zhí)行SQL語句的接口,專門執(zhí)行業(yè)務(wù)系統(tǒng)發(fā)送的那些CRUD語句

因此MySQL的工作線程接收到SQL語句之后,就會(huì)轉(zhuǎn)交給SQL接口去執(zhí)行:

查詢解析器

那SQL接口怎么執(zhí)行SQL語句的?這玩意能懂這些SQL語句?

假設(shè)有如下SQL:

select id,name,age from users where id=1

這就需要查詢解析器(Parser),負(fù)責(zé)解析SQL語句,比如對(duì)那個(gè)SQL拆解成:

  • 要從“users”表里查詢數(shù)據(jù)
  • 查詢“id”字段的值等于1的那行數(shù)據(jù)
  • 對(duì)查出來的那行數(shù)據(jù)要提取里面的“id,name,age”三字段

SQL解析也就是按SQL語法來解析SQL語句意欲何為:

查詢優(yōu)化器

通過解析器知道SQL要干啥了,然后就得找查詢優(yōu)化器(Optimizer)選擇一個(gè)最優(yōu)查詢路徑。

啥叫最優(yōu)查詢路徑呢?

之前的那個(gè)SQL:從“users”表里查詢數(shù)據(jù),查“id”字段的值等于1的那行數(shù)據(jù),對(duì)查出來的那行數(shù)據(jù)要提取里面的“id,name,age”三個(gè)字段。

要完成此事有如下查詢路徑:

  • 直接定位到users表中的id字段等于1的那行數(shù)據(jù),查出來那行數(shù)據(jù)的id、name、age三個(gè)字段值
  • 先把users表中的每行數(shù)據(jù)的“id,name,age”三個(gè)字段的值都查出來,然后從這批數(shù)據(jù)里過濾出來“id”字段等于1的那行數(shù)據(jù)的“id,name,age”三個(gè)字段

可見,完成該SQL,兩條路徑都能實(shí)現(xiàn),那到底選哪個(gè)呢?顯然第一種性能更好。

所以查詢優(yōu)化器大概就是這個(gè)意義,他會(huì)針對(duì)你的SQL生成查詢路徑樹,選擇最優(yōu)查詢路徑。

調(diào)用存儲(chǔ)引擎接口,真正執(zhí)行SQL語句。

把查詢優(yōu)化器選擇的最優(yōu)查詢路徑,即到底應(yīng)該按照一個(gè)什么樣的順序和步驟去執(zhí)行這個(gè)SQL語句的計(jì)劃,把該計(jì)劃交給底層的存儲(chǔ)引擎去真正執(zhí)行。

假設(shè)我們的數(shù)據(jù)有的存在內(nèi)存,有的存在磁盤文件,那到底怎么知道

  • 哪些數(shù)據(jù)在內(nèi)存?
  • 哪些在磁盤?

執(zhí)行時(shí):

  • 是更新內(nèi)存數(shù)據(jù)?
  • 還是更新磁盤數(shù)據(jù)?

若更新磁盤數(shù)據(jù):

  • 先查詢哪個(gè)磁盤文件
  • 再更新哪個(gè)磁盤文件?

這就需要存儲(chǔ)引擎,就是個(gè)執(zhí)行SQL語句的,會(huì)按步驟查詢內(nèi)存緩存數(shù)據(jù),更新磁盤數(shù) 據(jù),查詢磁盤數(shù)據(jù)等,執(zhí)行此類的一系列的操作:

MySQL架構(gòu)設(shè)計(jì)中,SQL接口、SQL解析器、查詢優(yōu)化器都是通用的,屬于一套組件。但支持各種存儲(chǔ)引擎,如InnoDB、MyISAM、Memory等,可以選擇具體使用哪種存儲(chǔ)引擎來負(fù)責(zé)執(zhí)行SQL。

執(zhí)行器

根據(jù)執(zhí)行計(jì)劃調(diào)用存儲(chǔ)引擎的接口。

存儲(chǔ)引擎可幫助我們?nèi)ピL問內(nèi)存及磁盤上的數(shù)據(jù),那誰來調(diào)存儲(chǔ)引擎的接口?

那就是執(zhí)行器,會(huì)根據(jù)優(yōu)化器選擇的執(zhí)行方案,按照一定的順序和步驟調(diào)用存儲(chǔ)引擎的接口,執(zhí)行SQL邏輯。

比如執(zhí)行器可能先調(diào)用存儲(chǔ)引擎的一個(gè)接口,獲取“users”表中的第一行數(shù)據(jù),然后判斷一下這個(gè)數(shù)據(jù)的“id”字段的值是否等于我們期望的一個(gè)值,如果不是的話,那就繼續(xù)調(diào)用存儲(chǔ)引擎的接口,去獲取“users”表的下一行數(shù)據(jù)。

也就這套操作,執(zhí)行器會(huì)根據(jù)優(yōu)化器生成的執(zhí)行計(jì)劃,不停調(diào)用存儲(chǔ)引擎的接口們,去完成SQL語句的執(zhí)行計(jì)劃,即不停的更新或提取一些數(shù)據(jù):

到此這篇關(guān)于MySQL通透詳解架構(gòu)設(shè)計(jì)的文章就介紹到這了,更多相關(guān)MySQL 架構(gòu)設(shè)計(jì)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql5.7.19 解壓版安裝教程詳解(附送純凈破解中文版SQLYog)

    mysql5.7.19 解壓版安裝教程詳解(附送純凈破解中文版SQLYog)

    Mysql5.7.19版本是今年新推出的版本,最近幾個(gè)版本的MySQL都不再是安裝版,都是解壓版了,大家在使用過程中遇到很多問題,下面小編給大家?guī)砹薓ySQL5.7.19 解壓版安裝教程詳解,感興趣的朋友一起看看吧
    2017-10-10
  • MySql約束超詳細(xì)介紹

    MySql約束超詳細(xì)介紹

    MySQL唯一約束(Unique?Key)是指所有記錄中字段的值不能重復(fù)出現(xiàn)。例如,為?id?字段加上唯一性約束后,每條記錄的?id?值都是唯一的,不能出現(xiàn)重復(fù)的情況
    2022-09-09
  • MySQL?常用引擎總結(jié)分享

    MySQL?常用引擎總結(jié)分享

    這篇文章主要介紹了MySQL?常用引擎總結(jié)分享,MySQL有很多存儲(chǔ)引擎,所謂的存儲(chǔ)引擎是指用于存儲(chǔ)、處理和保護(hù)數(shù)據(jù)的核心服務(wù),更多常用引擎分享,需要的小伙伴可以參考下面文章內(nèi)容
    2022-06-06
  • MySQL修改默認(rèn)引擎和字符集詳情

    MySQL修改默認(rèn)引擎和字符集詳情

    這篇文章小編主要介紹的是MySQL修改默認(rèn)引擎和字符集的相關(guān)資料,需要的小伙伴請(qǐng)參考下面文章的具體內(nèi)容,希望能否幫助到您
    2021-09-09
  • mysql常見問題解決

    mysql常見問題解決

    網(wǎng)上看到了不錯(cuò)的mysql下常見錯(cuò)誤解決方法,特整理下,方便大家學(xué)習(xí)mysql
    2008-02-02
  • 在MySQL中使用子查詢和標(biāo)量子查詢的基本操作教程

    在MySQL中使用子查詢和標(biāo)量子查詢的基本操作教程

    這篇文章主要介紹了在MySQL中使用子查詢和標(biāo)量子查詢的基本操作教程,子查詢的使用時(shí)MySQL入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-12-12
  • 淺談mysql一張表到底能存多少數(shù)據(jù)

    淺談mysql一張表到底能存多少數(shù)據(jù)

    這篇文章主要介紹了淺談mysql一張表到底能存多少數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • MySQL collation方法

    MySQL collation方法

    在以前用oracle的時(shí)候,很少關(guān)于它的collation方法,但是在mysql中,這點(diǎn)不加注意的話,卻有可能會(huì)出現(xiàn)問題。
    2008-10-10
  • MySQL 配置文件 my.cnf / my.ini 區(qū)別解析

    MySQL 配置文件 my.cnf / my.ini 區(qū)別解析

    充分理解 MySQL 配置文件中各個(gè)變量的意義對(duì)我們有針對(duì)性的優(yōu)化 MySQL 數(shù)據(jù)庫性能有非常大的意義,這篇文章主要介紹了MySQL 配置文件 my.cnf / my.ini 區(qū)別,需要的朋友可以參考下
    2022-11-11
  • mysql備份腳本 mysqldump使用方法詳解

    mysql備份腳本 mysqldump使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了mysql備份腳本(mysqldump),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11

最新評(píng)論