国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:54日期:2023-10-07 14:56:28

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

一點(diǎn)是因?yàn)镸ysql免費(fèi),相對(duì)昂貴的Oracle服務(wù),對(duì)于很多剛起步的公司來(lái)說(shuō),是最適合不過(guò)的數(shù)據(jù)庫(kù)了。

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

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

1.Connections 連接器

我們連接Mysql的服務(wù)作為客戶(hù)端連接Mysql服務(wù)端,Mysql可以連接各個(gè)編程語(yǔ)言平臺(tái)

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

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

3.連接池(Connection Pool)

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

4.SQL Interface(SQL接口)

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

5.Parse(解析器)

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

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

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

7.查詢(xún)緩存(Cache&Buffer)

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

8.存儲(chǔ)引擎(Pluggable Storage Engines)

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

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

平時(shí)涉及到存儲(chǔ)引擎的選型,主要針對(duì)業(yè)務(wù)的需要來(lái)選擇,可以參考各自的特點(diǎn)。

存儲(chǔ)引擎的選型:InnoDB:

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

MyISAM:

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

MEMORY:

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

這里有一張MYSQL的簡(jiǎn)單執(zhí)行流程圖,憑靠這張圖對(duì)MYSQL整體的一個(gè)執(zhí)行流程會(huì)有清晰的認(rèn)識(shí)。

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

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

以上就是深入了解Mysql邏輯架構(gòu)的詳細(xì)內(nèi)容,更多關(guān)于Mysql邏輯架構(gòu)的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 久热精品免费视频 | 欧美日韩一区二区三区视频 | 欧美亚洲影院 | 亚洲国产精久久久久久久 | 美国一级片免费看 | 日本加勒比在线视频 | 成人毛片免费观看视频在线 | 精品伊人久久久久网站 | 亚洲巨乳自拍在线视频 | 久久久日韩精品国产成人 | 国产成人午夜精品免费视频 | 在线高清一级欧美精品 | 久久99精品久久久久久综合 | 高跟丝袜美女一级毛片 | 久久伊人男人的天堂网站 | 久久精品国产亚洲网址 | 国产视频二区 | 九九九国产在线 | 亚洲国产成人在线观看 | 国产成人资源 | 久久精品国产免费看久久精品 | a级国产乱理伦片在线观看 a级国产乱理伦片在线观看99 | 日本69xxxxxxxxx69| 欧美高清在线视频在线99精品 | 亚洲天堂网在线播放 | 久久精品中文字幕首页 | 欧美videos另类齐全 | 国产精品系列在线一区 | 87精品福利视频在线观看 | 免费看美女午夜大片 | 99精品在线免费 | 亚洲国产成人久久精品图片 | 免费播放国产性色生活片 | 欧美国产日韩一区二区三区 | 在线亚洲精品视频 | 综合亚洲精品一区二区三区 | 欧美一级毛片免费高清aa | 亚洲天堂网在线视频 | 日朝欧美亚洲精品 | 亚洲精品一区二区久久 | 日韩视频久久 |