国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Mysql為什么只能支持2000w左右的數(shù)據(jù)量?

Mysql為什么只能支持2000w左右的數(shù)據(jù)量?

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-10-11 22:19:01 1697033941

一、Mysql為什么只能支持2000w左右的數(shù)據(jù)量

簡(jiǎn)而言之,是B+樹的層數(shù)問題。

假設(shè)表中一行記錄的數(shù)據(jù)大小為1k(實(shí)際上現(xiàn)在很多互聯(lián)網(wǎng)業(yè)務(wù)數(shù)據(jù)記錄大小通常就是1K左右)

所以(主鍵索引中)葉子節(jié)點(diǎn)的一個(gè)節(jié)點(diǎn)(即一個(gè)page,且為數(shù)據(jù)頁(yè)),在這里認(rèn)為可以放16行記錄.

假設(shè)主鍵ID為bigint類型(長(zhǎng)度為8字節(jié)),而指針大小在InnoDB源碼中是6字節(jié),這樣一共14字節(jié),我們一個(gè)頁(yè)(Page,在此為目錄頁(yè))中能存放多少這樣的(索引)單元,其實(shí)就代表有多少指針,即16384/14=1170。即一個(gè)目錄Page,能存大概1170個(gè)(索引)單元.

那么可以算出一棵高度為2的B+樹,能存放1170*16=18720條這樣的數(shù)據(jù)記錄。

根據(jù)同樣原理, 可以算出一個(gè)高度為3的B+樹可以存放:1170*1170*16=21902400條這樣的記錄。

所以在InnoDB中B+樹高度一般為1-3層,就能滿足千萬(wàn)級(jí)的數(shù)據(jù)存儲(chǔ)。在查找數(shù)據(jù)時(shí)一次頁(yè)的查找代表一次磁盤IO,所以通過主鍵索引查詢通常只需要1-3次IO操作即可查找到數(shù)據(jù)。

所以如果 表A的數(shù)據(jù)行數(shù)為600多萬(wàn),B+樹高度為3;表B的數(shù)據(jù)行數(shù)只有15萬(wàn),B+樹高度也為3。可以看出盡管數(shù)據(jù)量差異較大,這兩個(gè)表樹的高度都是3,換句話說這兩個(gè)表通過索引查詢效率并沒有太大差異,因?yàn)槎贾恍枰?次IO。如果有一張表行數(shù)是一千萬(wàn),那么其B+樹高度依舊是3,查詢效率仍然不會(huì)相差太大。

當(dāng)然如果一張表只有5行數(shù)據(jù),那么它的B+樹高度為1。

即當(dāng)數(shù)據(jù)量在18720到21902400行之間時(shí),B+樹的高度都是3,查詢的速度幾乎相同.

因?yàn)槎植檎沂窃趦?nèi)存里邊進(jìn)行的,速度很快.和磁盤IO差幾個(gè)數(shù)量級(jí),可以忽略. 那么即從2萬(wàn)行記錄到2200萬(wàn)行記錄,主體的查詢性能差不多。

延伸閱讀:

二、數(shù)據(jù)庫(kù)的查詢功能實(shí)現(xiàn)原理

數(shù)據(jù)庫(kù)查詢是數(shù)據(jù)庫(kù)的最主要功能之一。我們都希望查詢數(shù)據(jù)的速度能盡可能的快,因此數(shù)據(jù)庫(kù)系統(tǒng)的設(shè)計(jì)者會(huì)從查詢算法的角度進(jìn)行優(yōu)化。最基本的查詢算法當(dāng)然是順序查找(linear search),這種復(fù)雜度為O(n)的算法在數(shù)據(jù)量很大時(shí)顯然是糟糕的,好在計(jì)算機(jī)科學(xué)的發(fā)展提供了很多更優(yōu)異的查找算法,例如二分查找(binary search)、二叉樹查找(binary tree search)等。如果稍微分析一下會(huì)發(fā)現(xiàn),每種查找算法都只能應(yīng)用于特定的數(shù)據(jù)結(jié)構(gòu)之上,例如二分查找要求被檢索數(shù)據(jù)有序,而二叉樹查找只能應(yīng)用于二叉查找樹上,但是數(shù)據(jù)本身的組織結(jié)構(gòu)不可能完全滿足各種數(shù)據(jù)結(jié)構(gòu)(例如,理論上不可能同時(shí)將兩列都按順序進(jìn)行組織),所以,在數(shù)據(jù)之外,數(shù)據(jù)庫(kù)系統(tǒng)還維護(hù)著滿足特定查找算法的數(shù)據(jù)結(jié)構(gòu),這些數(shù)據(jù)結(jié)構(gòu)以某種方式引用(指向)數(shù)據(jù),這樣就可以在這些數(shù)據(jù)結(jié)構(gòu)上實(shí)現(xiàn)高級(jí)查找算法。這種數(shù)據(jù)結(jié)構(gòu),就是索引。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
mysql inner join為什么不走索引?

一、mysql inner join為什么不走索引因?yàn)樗饕膬?yōu)勢(shì)是在大表中過濾出小的結(jié)果集進(jìn)行聯(lián)接,mysql inner join句根本沒有任何過濾條件。另外表很小...詳情>>

2023-10-11 23:07:14
Geode和redis兩個(gè)分布式內(nèi)存數(shù)據(jù)庫(kù)的對(duì)比,優(yōu)缺點(diǎn)?

一、Geode和redis兩個(gè)分布式內(nèi)存數(shù)據(jù)庫(kù)的對(duì)比兩者的定位不一樣。Geode是分布式內(nèi)存數(shù)據(jù)庫(kù),提供了可配置的一致性保證,能夠保證數(shù)據(jù)不丟失,更...詳情>>

2023-10-11 22:50:49
InnoDB的next-key lock為什么是左開右閉的?

一、InnoDB的next-key lock為什么是左開右閉的InnoDB的next-key lock本身的設(shè)計(jì)方案就是左開右閉的,例如select * from t where c2 = 10 fo詳情>>

2023-10-11 22:48:02
到底哪些APP在用Flutter?

一、滴滴出行滴滴出行是一款出行服務(wù)平臺(tái),提供打車、順風(fēng)車、單車等多種出行方式。在采用Flutter技術(shù)后,滴滴出行成功實(shí)現(xiàn)了Android和iOS平臺(tái)...詳情>>

2023-10-11 22:45:35
web前端和UI前端的區(qū)別?

一、職責(zé)不同Web前端主要負(fù)責(zé)開發(fā)網(wǎng)站的前端部分,通過編寫代碼實(shí)現(xiàn)網(wǎng)站的用戶界面和交互功能。而UI前端(也稱為UI設(shè)計(jì)師或UI工程師)負(fù)責(zé)設(shè)計(jì)...詳情>>

2023-10-11 22:40:09
快速通道