亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

深入了解Mysql邏輯架構(gòu)

 更新時間:2020年12月23日 10:06:46   作者:晴轉(zhuǎn)陣雨  
這篇文章主要介紹了深入了解Mysql邏輯架構(gòu)的原因,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下

  Mysql現(xiàn)在是大多數(shù)公司企業(yè)在用的數(shù)據(jù)庫,之所以用Mysql,一點是因為Mysql是開源軟件,一些有能力的公司會基于已有的Mysql架構(gòu),進行修改、調(diào)整改成適合自己公司的業(yè)務需要。

一點是因為Mysql免費,相對昂貴的Oracle服務,對于很多剛起步的公司來說,是最適合不過的數(shù)據(jù)庫了。

  之所以要認識Mysql的邏輯架構(gòu),就好比我們自己在做開發(fā)時,首先需要先掌握自己系統(tǒng)用的分層架構(gòu),這樣在開發(fā)的過程中,如果有哪個環(huán)節(jié)產(chǎn)生問題,就很好排查。認識Mysql的邏輯架構(gòu)也同理,我們在用Mysql的時候,我們不清楚它什么時候會出現(xiàn)問題,但是當出現(xiàn)問題時(比如優(yōu)化查詢sql,要從哪一步開始),我們可以更清楚的定位問題。

1.Connections 連接器

我們連接Mysql的服務作為客戶端連接Mysql服務端,Mysql可以連接各個編程語言平臺

2.系統(tǒng)管理和控制工具(Management Serveices & Utilities)

作為Mysql服務的管理和控制工具,比如備份、還原、復制、集群等

3.連接池(Connection Pool)

連接池的主要功能是提供連接認證、線程復用、連接數(shù)限制等

4.SQL Interface(SQL接口)

這里主要是接收Mysql 的DML、DDL語句,以及存儲過程、視圖、觸發(fā)器等

5.Parse(解析器)

這里主要的對傳過來的sql字符串進行解析,比如我們一開始接觸的jdbc編程,就是將字符串類型的sql語句發(fā)送到mysql里,然后解析器首先對sql語句進行詞法分析,形成語法樹,接著再對語法樹進行語法分析,看各個分詞是否符合SQL92標準,符合的話再執(zhí)行下一環(huán)節(jié)業(yè)務處理。

6.查詢優(yōu)化器(Optimizer)

查詢優(yōu)化器根據(jù)傳過來的SQL語句,進行分析判斷是否是最優(yōu)的執(zhí)行語句,主要針對一下三個方面進行分析:
* 使用哪一個索引(一個表有若干個索引,選擇過濾力度最大的那個)
* 多表關聯(lián)的表連接順序
* WHERE條件的先后順序(根據(jù)MYSQL最左前綴原則,會重新擺放條件順序)

7.查詢緩存(Cache&Buffer)

MYSQL會將每一條SQL進行hash處理后將hash值放到一個map中,每次有SQL來時先計算SQL的hash值,比較是否相同,相同的話可以執(zhí)行內(nèi)存的SQL,而不必對新的SQL語句進行解析、優(yōu)化等操作,加快執(zhí)行效率。

8.存儲引擎(Pluggable Storage Engines)

MSQL的存儲引擎支持可插拔特性,即用戶可隨意替換想用的存儲引擎,也可以自定義自己的存儲引擎,這里主要針對INNODB、MYISAM存儲引擎進行分析比較。

平時涉及到存儲引擎的選型,主要針對業(yè)務的需要來選擇,可以參考各自的特點。

存儲引擎的選型:

InnoDB:

支持事務處理,支持外鍵,支持崩潰修復能力和并發(fā)控制。如果需要對事務的完整性要求比較高(比如銀行),要求實現(xiàn)并發(fā)控制(比如售票),那選擇InnoDB有很大的優(yōu)勢。如果需要頻繁的更新、刪除操作的數(shù)據(jù)庫,也可以選擇InnoDB,因為支持事務的提交(commit)和回滾(rollback)。

MyISAM:

插入數(shù)據(jù)快,空間和內(nèi)存使用比較低。如果表主要是用于插入新記錄和讀出記錄,那么選擇MyISAM能實現(xiàn)處理高效率。如果應用的完整性、并發(fā)性要求比 較低,也可以使用。

MEMORY:

所有的數(shù)據(jù)都在內(nèi)存中,數(shù)據(jù)的處理速度快,但是安全性不高。如果需要很快的讀寫速度,對數(shù)據(jù)的安全性要求較低,不需要持久保存,可以選擇MEMOEY。它對表的大小有要求,不能建立太大的表。所以,這類數(shù)據(jù)庫只使用在相對較小的數(shù)據(jù)庫表。

  這里有一張MYSQL的簡單執(zhí)行流程圖,憑靠這張圖對MYSQL整體的一個執(zhí)行流程會有清晰的認識。

   MYSQL的邏輯架構(gòu)就介紹到這里。當然MYSQL還有對應的物理架構(gòu),不過這一塊主要涉及到MYSQL的各個日志文件,以及各個表的數(shù)據(jù)文件以及索引文件,在后面的章節(jié)再做介紹。

以上就是深入了解Mysql邏輯架構(gòu)的詳細內(nèi)容,更多關于Mysql邏輯架構(gòu)的資料請關注腳本之家其它相關文章!

相關文章

  • 使用Perl DBI操作MySQL的一些建議

    使用Perl DBI操作MySQL的一些建議

    這篇文章主要介紹了使用Perl DBI操作MySQL的一些建議,針對Perl下連接MySQL的DBD::MySQL這個模塊,需要的朋友可以參考下
    2015-05-05
  • 詳解grep獲取MySQL錯誤日志信息的方法

    詳解grep獲取MySQL錯誤日志信息的方法

    在本篇文章中小編給大家整理了關于通過grep 獲取MySQL錯誤日志信息的方法的相關知識點內(nèi)容,有需要的朋友們跟著學習下。
    2018-09-09
  • Mysql中聚簇索引和非聚簇索引的區(qū)別詳解

    Mysql中聚簇索引和非聚簇索引的區(qū)別詳解

    這篇文章主要介紹了Mysql中聚簇索引和非聚簇索引的區(qū)別詳解,聚簇索引就是按照每張表的主鍵構(gòu)造一顆B+樹,同時葉子節(jié)點中存放的就是整張表的行記錄數(shù)據(jù),也將聚集索引的葉子節(jié)點稱為數(shù)據(jù)頁,需要的朋友可以參考下
    2023-07-07
  • MySQL產(chǎn)生死鎖原因分析講解

    MySQL產(chǎn)生死鎖原因分析講解

    死鎖指的是在兩個或兩個以上不同的進程或線程中,由于存在共同資源的競爭或進程(或線程)間的通訊而導致各個線程間相互掛起等待,如果沒有外力作用,最終會引發(fā)整個系統(tǒng)崩潰
    2022-12-12
  • clickhouse復雜時間格式的轉(zhuǎn)換方式

    clickhouse復雜時間格式的轉(zhuǎn)換方式

    這篇文章主要介紹了clickhouse復雜時間格式的轉(zhuǎn)換方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • MySQL?去除字符串中的括號以及括號里的所有內(nèi)容

    MySQL?去除字符串中的括號以及括號里的所有內(nèi)容

    這篇文章主要介紹了MySQL?去除字符串中的括號以及括號里的所有內(nèi)容,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • MySQL通透詳解架構(gòu)設計

    MySQL通透詳解架構(gòu)設計

    這篇文章主要介紹了MySQL架構(gòu)設計相關基礎與原則,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2022-02-02
  • mysql/Java服務端對emoji的支持與問題解決方法詳解

    mysql/Java服務端對emoji的支持與問題解決方法詳解

    這篇文章主要介紹了mysql/Java服務端對emoji的支持與問題解決方法,結(jié)合實例形式分析了mysql/Java服務端對emoji字符集存儲及支持問題解決方法,需要的朋友可以參考下
    2019-10-10
  • MySQL阻塞與死鎖的解決

    MySQL阻塞與死鎖的解決

    本文主要介紹了MySQL阻塞與死鎖的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-09-09
  • 經(jīng)測試最好用的mysql密碼忘記的解決方法

    經(jīng)測試最好用的mysql密碼忘記的解決方法

    經(jīng)測試最好用的mysql密碼忘記的解決方法...
    2007-06-06

最新評論