在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

MySQL的頁結(jié)構(gòu)及原理

dyquk4xk2p3d ? 來源:良許Linux ? 作者:良許Linux ? 2022-11-05 12:56 ? 次閱讀

索引可以說是每個(gè)工程師的必備技能點(diǎn),明白索引的原理對于寫出高質(zhì)量的 SQL 至關(guān)重要,今天我們就從 0 到 1 來理解下索引的原理,相信大家看完不光對索引還會對 MySQL 中 InnoDB 存儲引擎的最小存儲單位「頁」會有更深刻的認(rèn)識

從實(shí)際需求出發(fā)

假設(shè)有如下用戶表:

CREATETABLE`user`(
`id`int(11)unsignedNOTNULLAUTO_INCREMENT,
`name`int(11)DEFAULTNULLCOMMENT'姓名',
`age`tinyint(3)unsignedDEFAULTNULLCOMMENT'年齡',
`height`int(11)DEFAULTNULLCOMMENT'身高',
PRIMARYKEY(`id`)
)ENGINE=InnoDBDEFAULTCHARSET=utf8COMMENT='用戶表';

可以看到存儲引擎使用的是 InnoDB,我們先來看針對此表而言工作中比較常用的 SQL 語句都有哪此,畢竟技術(shù)是要為業(yè)務(wù)需求服務(wù)的,

1.select*fromuserwhereid=xxx
2.select*fromuserorderbyidasc/desc
3.select*fromuserwhereage=xxx
4.selectagefromuserwhereage=xxx
5.selectagefromuserorderbyageasc/desc

既然要查詢那我們首先插入一些數(shù)據(jù)吧,畢竟沒有數(shù)據(jù)何來查詢

insertintouser('name','age','height')values('張三',20,170);
insertintouser('name','age','height')values('李四',21,171);
insertintouser('name','age','height')values('王五',22,172);
insertintouser('name','age','height')values('趙六',23,173);
insertintouser('name','age','height')values('錢七',24,174);

插入后表中的數(shù)據(jù)如下:

543bf432-5cc1-11ed-a3b6-dac502259ad0.jpg

不知你有沒發(fā)現(xiàn)我們在插入的時(shí)候并沒有指定 id 值,但 InnoDB 為每條記錄默認(rèn)添加了一個(gè) id 值,而且這個(gè) id 值是遞增的,每插入一條記錄,id 遞增 1,id 為什么要遞增呢,主要是為了查詢方便,每條記錄按 id 由小到大的順序用鏈表連接起來,這樣每次查找 id = xxx 的值就從 id = 1 開始依次往后查找即可

544b8f32-5cc1-11ed-a3b6-dac502259ad0.jpg

現(xiàn)在假設(shè)我們要執(zhí)行以下 SQL 語句,MySQL 會怎么查詢呢

select*fromuserwhereid=3

如前所述,首先從 id 最小的記錄也就是 id = 1 讀起,每次讀一條記錄,將其 id 值與要查詢的值比較,連續(xù)讀三次記錄于是找到了記錄 3,注意這個(gè)讀的操作,是首先需要把存儲在磁盤的記錄讀取到內(nèi)存然后再比較 id 的,從磁盤讀到內(nèi)存算一次 IO,也就是說此過程中產(chǎn)生了三次 IO,如果只是幾條記錄還好,但如果要比較的條數(shù)多的話對性能是非常嚴(yán)重的挑戰(zhàn),如果我要查詢?yōu)?id = 100 的記錄那豈不是要產(chǎn)生 100 次 IO?既然瓶頸在 IO,那該怎么改進(jìn)呢,很簡單,我們現(xiàn)在的設(shè)計(jì)一次 IO 只能讀一條記錄,那改為一次 IO 能讀取 100 條甚至更多不就只產(chǎn)生一次 IO 了嗎,這背后的思想就是程序局部性原理:當(dāng)用到了某項(xiàng)數(shù)據(jù)時(shí),很可能會用到與之相鄰的數(shù)據(jù),所以干脆把相依的數(shù)據(jù)一起加載進(jìn)去(你從 id = 1 開始讀,那很可能用到 id = 1 緊隨其后的元素,于是干脆把 id = 1 ~ id = 100 的記錄都加載進(jìn)去)

當(dāng)然一次 IO 的讀取記錄也并不是多多益善,總不能為了一條查詢記錄而把很多無關(guān)的數(shù)據(jù)都加載到內(nèi)存吧,那會造成資源的極大浪費(fèi),于是我們采用了一個(gè)比較折中的方案,我們規(guī)定一次 IO 讀取 16 K 的數(shù)據(jù),假設(shè)為 100 條數(shù)據(jù)好了,這樣如果我們要查詢 id = 100 的記錄,只產(chǎn)生了一次 IO 讀(id=1~id=100 的記錄),比起原來的 100 次 IO 提升了 100 倍的性能

5459b99a-5cc1-11ed-a3b6-dac502259ad0.jpg

我們把這 16KB 的記錄組合稱為一個(gè)

頁目錄

一次 IO 會讀取一個(gè)頁,然后再在內(nèi)存里查找頁里的記錄,在內(nèi)存里查找確實(shí)比磁盤快多了,但我們?nèi)圆粷M意,因?yàn)槿绻檎?id = 100 的記錄,要先從 id = 1 的記錄比較起,然后是id=2,…,id=100,需要比較 100 次,能否更快一點(diǎn)?

可以參照二分查找,先查找 id = (1+100)/2 = 50,由于 50 < 100,接著在 ?50~100 的記錄中查,然后再在 75~100 中查,這樣經(jīng)過 7 次就可找到 id = 100 次的記錄,比起原來的 100 次比較又提升了不少性能。但現(xiàn)在問題來了,第一次要找到 id = ?50 的記錄又得從 id = 1 開始遍歷 50 次才能找到,能否一下就定位到 id=50 的記錄呢,如果不能,哪怕第一次從 id = 30 或 40 開始查找也行啊

有什么數(shù)據(jù)結(jié)構(gòu)能滿足這種需求呢,還記得跳表不,每隔 n 個(gè)元素抽出一個(gè)組成一級索引,每隔 2*n 個(gè)元素組成二級索引。。。

547d360e-5cc1-11ed-a3b6-dac502259ad0.jpg

如圖示,以建立一級索引為例,我們在查找的時(shí)候先在一級索引查找,在一級索引里定位到了再到鏈表里查找,比如我們要找 7 這個(gè)數(shù)字,如果不用跳表直接在鏈表里查,需要比較 7 次,而如果用了跳表我們先在一級索引查找,發(fā)現(xiàn)只要比較 3 次,減少了四次,所以我們可以利用跳表的思想來減少查詢次數(shù),具體操作如下,每 4 個(gè)元素為一組組成一個(gè)槽(slot),槽只記錄本組元素最大的那條記錄以及記錄本組有幾條記錄

54c67ecc-5cc1-11ed-a3b6-dac502259ad0.jpg

現(xiàn)在假設(shè)我們想要定位 id = 9 的那條記錄,該怎么做呢,很簡單:首先定位記錄在哪個(gè)槽,然后遍歷此槽中的元素

定位在哪個(gè)槽,首先取最小槽和最大槽對應(yīng)的 id(分別為 4, 12),先通過二分查找取它們的中間值為 (4+12)/2 = 8,8 小于 9,且槽 2 的最大 id 為 12,所以可知 id = 9 的記錄在槽 2 里

遍歷槽 2 中的元素,現(xiàn)在問題來了,我們知道每條記錄都構(gòu)成了一個(gè)單鏈表,而每個(gè)槽指向的是此分組中的最大 id 值,該怎么從此槽的第一個(gè)元素開始遍歷呢,很簡單,從槽 1 開始遍歷不就行了,因?yàn)樗赶蛟氐南乱粋€(gè)元素即為槽 2 的起始元素,遍歷后發(fā)現(xiàn)槽 2 的 第一個(gè)元素即為我們找到的 id 為 9 的元素

可以看到通過這種方式在頁內(nèi)很快把我們的元素定位出來了,MySQL 規(guī)定每個(gè)槽中的元素在 1~8 條,所以只要定位了在哪個(gè)槽,剩下的比較就不是什么問題了,當(dāng)然一個(gè)頁裝的記錄終究是有限的,如果頁滿了,就要要開辟另外的頁來裝記錄了,頁與頁之間通過鏈表連接起來,但注意看下圖,為啥要用雙向鏈表連接起來呢,別忘了最開頭我們列出的 「order by id asc 」和「order by id desc 」這兩個(gè)查詢條件,也就是說記錄需要同時(shí)支持正序與逆序查找,這就是為什么要使用雙向鏈表的原因

54ecf1a6-5cc1-11ed-a3b6-dac502259ad0.jpg

B+ 樹的誕生

現(xiàn)在問題來了,如果有很多頁,該怎么定位元素呢,如果元素剛好在前幾個(gè)頁還好,大不了遍歷前幾個(gè)頁也很快,但如果要查 id = 100w 這樣的元素一頁頁遍歷的話就要遍歷 1w 頁(假設(shè)每頁 100 條記錄),那顯然是不可接受的,如何改進(jìn)呢,其實(shí)之前建的頁內(nèi)目錄已經(jīng)給了我們啟發(fā),既然在頁內(nèi)我們可以通過為記錄建頁目錄的形式來先定位元素在哪個(gè)槽然后再找,那針對多頁,能否先定位元素在哪個(gè)頁呢,也就是說我們可以為頁也建立一個(gè)目錄,這個(gè)目錄里的每一條記錄都對應(yīng)著頁及頁中的最小記錄,當(dāng)然這個(gè)目錄也是以頁的形式存在的,為了便于區(qū)分 ,我們把針對頁生成的目錄對應(yīng)的頁稱為目錄頁,而之前存儲完整記錄的頁稱為數(shù)據(jù)頁

5515e80e-5cc1-11ed-a3b6-dac502259ad0.jpg

畫外音:目錄頁與數(shù)據(jù)頁一樣,內(nèi)部也是有槽的,上文為了方便展示,沒有畫出,目錄頁和數(shù)據(jù)除了記錄數(shù)據(jù)不一樣,其他結(jié)構(gòu)都是一致的

現(xiàn)在如果要查找 id = xxx 的記錄就很簡單了,只要先到目錄頁中定位它的起始頁然后再依次查找即可,由于不管是目錄頁還是數(shù)據(jù)頁里面都有槽,所以無論是定位目錄頁的頁碼還是定位數(shù)據(jù)頁中的記錄都是非常快的。

當(dāng)然了,隨著頁的增多,目錄頁存放的記錄也越來越多,目錄頁也終歸會滿的,那就再建一個(gè)目錄頁吧,于是現(xiàn)在問題來了,怎么定位要找的 id 是在哪個(gè)目錄頁呢,再次制定針對目錄頁的目錄頁不就行了,如下

553d4a84-5cc1-11ed-a3b6-dac502259ad0.jpg

看到上面這個(gè)結(jié)構(gòu)你想到了什么?沒錯(cuò),這就是一顆 B+ 樹!到此相信你已經(jīng)明白了 B+ 樹的演進(jìn)之路,也明白了它的原理,可以看到這顆 B+ 樹有三層,我們把最頂層的目錄頁稱為根節(jié)點(diǎn),最下層的存儲完整記錄的頁稱為葉子節(jié)點(diǎn),

現(xiàn)在我們再來看一下如何查找 id = 55 的記錄,首先會加載根節(jié)點(diǎn),發(fā)現(xiàn)應(yīng)該在頁碼 30 的頁中去找,于是加載頁 30,在頁 30 中又發(fā)現(xiàn)應(yīng)該在頁 4 中查中,于是再次把頁 4 加載進(jìn)內(nèi)存中,然后在頁 4 中依次遍歷查找,可以看到總共經(jīng)歷了 3 次 IO(B+樹有幾層就會有幾次 IO),頁讀取之后會緩存在內(nèi)存中,再讀的話如果命中內(nèi)存中的頁就會直接從內(nèi)存中獲取。有人可能會問,如果 B+ 樹層數(shù)很多,那豈不是可能會有很多次 IO,我們簡單的算一下,假設(shè)數(shù)據(jù)頁可以存儲 100 條記錄,目錄頁可以存儲 1000 條記錄(目錄頁由于只存儲了主鍵,不存儲完整的數(shù)據(jù),所以可以存儲更多的記錄),那么

如果B+樹只有 1 層,也就是只有 1 個(gè)用于存放用戶記錄的節(jié)點(diǎn),最多能存放100條記錄。

如果B+樹有 2 層,最多能存放1000×100=100000條記錄。

如果B+樹有 3 層,最多能存放1000×1000×100=100000000條記錄。

如果B+樹有 4 層,最多能存放1000×1000×1000×100=100000000000條記錄!

所以一般3~4 層的 B+ 樹足以滿足我們的要求,而且每次讀取后會緩存在內(nèi)存中(當(dāng)然也會根據(jù)一定的算法被換出內(nèi)存),所以整體來看 3~4 層 B+ 樹足以滿足我們需求

聚簇索引與非聚簇索引

相信你已經(jīng)發(fā)現(xiàn)了,上文中我們舉的 B+ 樹的例子針對的是 id 也就是主鍵的索引,不難發(fā)現(xiàn)主鍵索引中的葉子結(jié)點(diǎn)存儲了完整的 SQL 記錄,我們把這種存儲了完整記錄的索引稱為聚簇索引,只要你定義了主鍵,那么主鍵索引就是聚簇索引。

那么如果是非主鍵的列創(chuàng)建的索引又是怎樣的形式呢,非葉子節(jié)點(diǎn)的形式完全一樣,但葉子節(jié)點(diǎn)的存儲則有些不同,非主鍵列索引葉子節(jié)點(diǎn)上存儲的是索引列及主鍵值,比如我們假設(shè)對 age 這個(gè)列建立了索引,那么它的索引樹如下

556c81d2-5cc1-11ed-a3b6-dac502259ad0.jpg

可以看到非葉子節(jié)點(diǎn)保存的是「age 值 + 頁碼」,而葉子節(jié)點(diǎn)保存的是 「age 值+主鍵值」,那么你可能就會疑惑了,如下 SQL 是怎么取出完整記錄的呢

select*fromuserwhereage=xxx

第一步大家都知道,上述 SQL 可以命中 age 列對應(yīng)的索引,然后找到葉子節(jié)點(diǎn)上對應(yīng)的記錄(如果有的話),但葉子節(jié)點(diǎn)上的記錄只有 age 和 id 這兩列,而你用的是 select *,意味著要查找 user 的所有列信息,該怎么辦呢,答案是根據(jù)拿到的 id 再到聚簇索引找 id 對應(yīng)的完整記錄,這就是我們所說的回表,如果回表多的話顯然會造成一定的性能問題,因?yàn)?id 可能分布在不同的頁中,這意味著要將不同的頁從磁盤讀入內(nèi)存,這些頁很可能不是相鄰的,也就意味著會造成大量的隨機(jī) IO,會嚴(yán)重地影響性能,看到這相信大家不難明白一道高頻面試題:為什么設(shè)置了命中了索引但還是造成了全表掃描,其中一個(gè)原因就是雖然命中了索引但在葉子節(jié)點(diǎn)查詢到記錄后還要大量的回表,導(dǎo)致優(yōu)化器認(rèn)為這種情況還不如全表掃描會更快些

有人可能會問,為啥都二級索引不存儲完整的記錄呢,當(dāng)然是為了節(jié)省空間,畢竟完整的數(shù)據(jù)是很耗空間的,如果每加一個(gè)索引都要額外存儲完整的記錄,那會造成很多數(shù)據(jù)冗余。

怎么避免這種情況呢?索引覆蓋,如果如下 SQL 滿足你的需求,那么就建議采用如下形式

selectagefromuserwhereage=xxx
selectage,idfromuserwhereage=xxx

不難發(fā)現(xiàn)這種 SQL 的特點(diǎn)是要獲取的列(age)就是索引列本身(包括 id),這樣在根據(jù) age 的索引查到葉子節(jié)上對應(yīng)的記錄后,由于記錄本身就包含了這些列,就不需要回表了,能提升性能

磁盤預(yù)讀

接下來我們討論一個(gè)網(wǎng)上很多人搞不拎清的一個(gè)問題,我們知道操作系統(tǒng)是以頁為單位來管理內(nèi)存的,在 Linux 中,一頁的大小默認(rèn)為 4 KB,也就是說無論是從磁盤載入數(shù)據(jù)到內(nèi)存還是將內(nèi)存寫回磁盤,操作系統(tǒng)都會以頁為單位進(jìn)行操作,哪怕你只對一個(gè)空文件只寫入了一個(gè)字節(jié),操作系統(tǒng)也會為其分配一個(gè)頁的大?。?4 KB)

55ba73ba-5cc1-11ed-a3b6-dac502259ad0.jpg

如圖示,向磁盤寫入了兩個(gè) byte ,但操作系統(tǒng)依然為其分配了一個(gè)頁(4 KB)的大小

innoDB 也是以頁為單位來存儲與讀取的,而 innoDB 頁的默認(rèn)大小為 16 KB,那么網(wǎng)上很多人的疑問是這是否意味著它需要執(zhí)行 4 次 IO 才能把 innoDB 的頁讀完呢?不是的,只需要一次 IO,為什么?這需要理解一點(diǎn)磁盤讀取數(shù)據(jù)的工作原理

磁盤的構(gòu)造

首先我們來看看磁盤的物理結(jié)構(gòu)

55cda6b0-5cc1-11ed-a3b6-dac502259ad0.jpg

硬盤內(nèi)部主要部件為磁盤盤片、傳動磁臂、讀寫磁頭和轉(zhuǎn)軸,數(shù)據(jù)主要寫入磁盤的盤片上的,盤片又是由若干個(gè)扇區(qū)構(gòu)成的,數(shù)據(jù)寫入讀取都是以扇區(qū)為基本單位的,另外以盤片中心為圓心,把盤片分成若干個(gè)同心圓,那每一個(gè)劃分圓的“線條”,就稱為磁道

那么數(shù)據(jù)是如何讀取與寫入的呢,主要有三步

尋道:既然數(shù)據(jù)是保存在扇區(qū)上的,那我首先我們需要知道它到底是在哪個(gè)扇區(qū)上吧,這就需要先讓磁頭移動到扇區(qū)所在的磁道上,我們把它稱為尋道時(shí)間,平均尋道時(shí)間一般在3-15ms

旋轉(zhuǎn)延遲: 磁盤移動到扇區(qū)所在的磁盤上時(shí),此時(shí)的磁頭對準(zhǔn)的還不一定我們想要的數(shù)據(jù)對應(yīng)的扇區(qū),所以需要等待盤片旋轉(zhuǎn)片刻,等到我們想要的數(shù)據(jù)對應(yīng)的扇區(qū)落到磁頭下,旋轉(zhuǎn)延遲取決于磁盤轉(zhuǎn)速,通常用磁盤旋轉(zhuǎn)一周所需時(shí)間的1/2表示。比如:7200rpm的磁盤平均旋轉(zhuǎn)延遲大約為60*1000/7200/2 = 4.17ms,而轉(zhuǎn)速為15000rpm的磁盤其平均旋轉(zhuǎn)延遲為2ms

數(shù)據(jù)傳輸:經(jīng)過前面的兩步,磁頭終于開始讀寫數(shù)據(jù)了,目前IDE/ATA能達(dá)到133MB/s,SATA II可達(dá)到300MB/s的接口數(shù)據(jù)傳輸率,數(shù)據(jù)傳輸時(shí)間通常遠(yuǎn)小于前兩部分消耗時(shí)間??珊雎圆挥?jì)

注意數(shù)據(jù)傳輸中的忽略不計(jì)是有前提的,即是需要讀取連續(xù)相鄰的扇區(qū),也就是我們常說的順序 IO,磁盤順序 IO 的讀寫速度可以媲美甚至超越內(nèi)存的隨機(jī) IO,所以這部分時(shí)間可以忽略不計(jì),(大家熟知的 Kafka 之所以性能強(qiáng)悍,有一個(gè)重要原因就是利用了磁盤的順序讀寫),但如果要讀取的數(shù)據(jù)是分布在不同的扇區(qū)的話,也就變成了隨機(jī) IO,隨機(jī) IO 毫無疑問增大了尋道時(shí)間和旋轉(zhuǎn)延遲,性能是非??皯n的(典型代表就是上文提到的 回表時(shí)大量 id 分布在不同的頁上,造成了大量的隨機(jī) IO)

55e244e4-5cc1-11ed-a3b6-dac502259ad0.jpg

如圖示:圖片來自著名學(xué)術(shù)期刊 ACM Queue 上的性能對比圖,可以看到磁盤順序 IO(Sequential Disk)的速度比內(nèi)存隨機(jī)讀寫(Random memory)還快

那讀取 innoDB 中的一個(gè)頁為啥算一次 IO 呢,相信你已經(jīng)猜到了,因?yàn)檫@一個(gè)頁是連續(xù)分配的,也即意味著它們的扇區(qū)是相鄰的,所以它是順序 IO

操作系統(tǒng)是以頁為單位來管理內(nèi)存的,它可以一次加載整數(shù)倍的頁,而 innoDB 的頁大小為 16KB,剛好是操作系統(tǒng)頁(4KB)的 4 倍,所以可以指定在讀取的起始地址連續(xù)讀取 4 個(gè)操作系統(tǒng)頁,即 16 KB,這就是我們說的磁盤預(yù)讀,至此相信大家不難明白為啥說讀取一頁其實(shí)只是一次 IO 而不是 4 次了

總結(jié)

看完本文相信大家能明白索引的由來了,此外對頁以及磁盤預(yù)讀對性能的提升應(yīng)該也有不少了解,其實(shí) MySQL 的頁結(jié)構(gòu)與我們推演的結(jié)構(gòu)有些許出入,不過不影響整體的理解。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 存儲
    +關(guān)注

    關(guān)注

    13

    文章

    4509

    瀏覽量

    87151
  • SQL
    SQL
    +關(guān)注

    關(guān)注

    1

    文章

    782

    瀏覽量

    44882
  • MySQL
    +關(guān)注

    關(guān)注

    1

    文章

    849

    瀏覽量

    27653

原文標(biāo)題:你管這破玩意叫B+樹?

文章出處:【微信號:良許Linux,微信公眾號:良許Linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    詳解Linux系統(tǒng)文件表目錄和Linux系統(tǒng)結(jié)構(gòu)

    表:是一種特殊的數(shù)據(jù)結(jié)構(gòu),記錄著頁面和框的對應(yīng)關(guān)系。(映射表) 表的作用:是內(nèi)存非連續(xù)分區(qū)分配的基礎(chǔ),實(shí)現(xiàn)從邏輯地址轉(zhuǎn)化成物理地址。
    的頭像 發(fā)表于 05-11 09:22 ?5583次閱讀
    詳解Linux系統(tǒng)文件<b class='flag-5'>頁</b>表目錄和Linux系統(tǒng)<b class='flag-5'>頁</b>表<b class='flag-5'>結(jié)構(gòu)</b>

    mysql表的結(jié)構(gòu)修改、約束

    mysql結(jié)構(gòu)修改、約束(二)
    發(fā)表于 05-21 10:26

    PHP/MySQL教程

    PHP/MySQL教程(一)  PHP/MySQL教程(二)  PHP/MySQL教程(三)  PHP/MySQL教程(四)  PHP/
    發(fā)表于 01-10 23:43 ?0次下載

    redis緩存mysql數(shù)據(jù)

    用Redis作Mysql數(shù)據(jù)庫緩存,必須解決2個(gè)問題。首先,應(yīng)該確定用何種數(shù)據(jù)結(jié)構(gòu)存儲來自Mysql的數(shù)據(jù);在確定數(shù)據(jù)結(jié)構(gòu)之后,還要考慮用什么標(biāo)識作為該數(shù)據(jù)
    的頭像 發(fā)表于 02-09 15:42 ?4219次閱讀

    MySQL數(shù)據(jù)結(jié)構(gòu)及算法原理的介紹

    本文以MySQL數(shù)據(jù)庫為研究對象,討論與數(shù)據(jù)庫索引相關(guān)的一些話題。特別需要說明的是,MySQL支持諸多存儲引擎,而各種存儲引擎對索引的支持也各不相同,因此MySQL數(shù)據(jù)庫支持多種索引類型,如
    的頭像 發(fā)表于 07-22 12:10 ?3468次閱讀
    <b class='flag-5'>MySQL</b>數(shù)據(jù)<b class='flag-5'>結(jié)構(gòu)</b>及算法原理的介紹

    理解MySQL體系結(jié)構(gòu)的數(shù)據(jù)庫和實(shí)例

    在面試中經(jīng)常會問MySQL的體系結(jié)構(gòu),接下來詳細(xì)分析MySQL的體系結(jié)構(gòu)之前先理解數(shù)據(jù)庫和實(shí)例兩個(gè)概念。
    的頭像 發(fā)表于 05-03 17:28 ?2453次閱讀

    MySQL中的高級內(nèi)容詳解

    之前兩篇文章帶你了解了 MySQL 的基礎(chǔ)語法和 MySQL 的進(jìn)階內(nèi)容,那么這篇文章我們來了解一下 MySQL 中的高級內(nèi)容。 其他文章: 138 張圖帶你 MySQL 入門 47
    的頭像 發(fā)表于 03-11 16:55 ?2428次閱讀
    <b class='flag-5'>MySQL</b>中的高級內(nèi)容詳解

    MySQL中的redo log是什么

    時(shí),InnoDB存儲引擎會使用redo log恢復(fù)數(shù)據(jù),保證數(shù)據(jù)的持久性與完整性。 上一篇中阿星講過,MySQL中數(shù)據(jù)是以為單位,你查詢一條
    的頭像 發(fā)表于 09-14 09:40 ?2230次閱讀

    剖析MySQL InnoDB存儲原理(上)

    一、MySQL記錄的存儲結(jié)構(gòu): 1、Page的結(jié)構(gòu),如下圖:
    的頭像 發(fā)表于 02-15 15:45 ?590次閱讀
    剖析<b class='flag-5'>MySQL</b> InnoDB存儲原理(上)

    什么是MySql?

    MySQL 是最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),數(shù)據(jù)庫(Database)是按照數(shù)據(jù)結(jié)構(gòu)來組織、存儲和管理數(shù)據(jù)的倉庫。
    的頭像 發(fā)表于 02-27 15:25 ?1316次閱讀
    什么是<b class='flag-5'>MySql</b>?

    MySQL高級進(jìn)階:索引優(yōu)化

    MySQL官方對于索引的定義:索引是幫助MySQL高效獲取數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu)。
    的頭像 發(fā)表于 06-11 11:13 ?827次閱讀
    <b class='flag-5'>MySQL</b>高級進(jìn)階:索引優(yōu)化

    id的機(jī)制不同在mysql的索引結(jié)構(gòu)以及優(yōu)缺點(diǎn)

    1.4.效率測試結(jié)果 二、使用uuid和自增id的索引結(jié)構(gòu)對比 2.1.使用自增id的內(nèi)部結(jié)構(gòu) 2.2.使用uuid的索引內(nèi)部結(jié)構(gòu) 2.3.使用自增id的缺點(diǎn) 三、總結(jié) 前言 在mysql
    的頭像 發(fā)表于 06-30 10:19 ?1002次閱讀
    id的機(jī)制不同在<b class='flag-5'>mysql</b>的索引<b class='flag-5'>結(jié)構(gòu)</b>以及優(yōu)缺點(diǎn)

    MySQL為什么選擇B+樹作為索引結(jié)構(gòu)?

    MySQL中,無論是Innodb還是MyIsam,都使用了B+樹作索引結(jié)構(gòu)(這里不考慮hash等其他索引)。本文將從最普通的二叉查找樹開始,逐步說明各種樹解決的問題以及面臨的新問題,從而說明MySQL為什么選擇B+樹作為索引
    的頭像 發(fā)表于 07-20 11:28 ?1191次閱讀
    <b class='flag-5'>MySQL</b>為什么選擇B+樹作為索引<b class='flag-5'>結(jié)構(gòu)</b>?

    MySQL導(dǎo)出的步驟

    MySQL是一種常用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),用于存儲和管理大量的結(jié)構(gòu)化數(shù)據(jù)。在實(shí)際應(yīng)用中,我們經(jīng)常需要將MySQL數(shù)據(jù)庫中的數(shù)據(jù)導(dǎo)出到其他地方,如備份數(shù)據(jù)、數(shù)據(jù)遷移、數(shù)據(jù)分析等。下面是使用My
    的頭像 發(fā)表于 11-21 10:58 ?1256次閱讀

    適用于MySQL的dbForge架構(gòu)比較

    dbForge Schema Compare for MySQL 是一種工具,用于輕松有效地比較和部署 MySQL 數(shù)據(jù)庫結(jié)構(gòu)和腳本文件夾差異。該工具提供了 MySQL 數(shù)據(jù)庫架構(gòu)中所
    的頭像 發(fā)表于 10-28 09:41 ?531次閱讀
    適用于<b class='flag-5'>MySQL</b>的dbForge架構(gòu)比較
    主站蜘蛛池模板: 国产在线a不卡免费视频 | 天堂bt在线 | 亚欧人成精品免费观看 | 亚洲狠狠色丁香婷婷综合 | 亚洲影视一区二区 | 狠狠色噜噜狠狠狠狠奇米777 | 欧美在线激情 | 高h办公室 | 人人澡人 | 影院成人区精品一区二区婷婷丽春院影视 | 日韩精品午夜 | 欧美综合精品一区二区三区 | 久久久久88色偷偷免费 | 午夜小视频网站 | 狼色网站 | 日本高清视频色wwwwww色 | 色综合激情丁香七月色综合 | 黄色录像日本 | 精品国产免费观看一区高清 | 亚洲欧美一区二区三区在线播放 | 日本夜夜操 | 性欧美bbbbbb| 免费在线观看一级毛片 | 婷婷六月丁 | 在线播放一区二区精品产 | 两性午夜欧美高清做性 | 国产自在自线午夜精品视频 | 亚洲无吗在线视频 | 人人爱人人艹 | 性色xxx | 2020av在线播放| 五月婷婷一区二区 | 久久久久琪琪免费影院 | 俺来也久久 | 综合爱爱 | 久久久www免费人成看片 | 亚洲午夜久久影院 | 久久久午夜精品 | 国产亚洲小视频 | 午夜久久网 | av福利网址网站 |