主頁 > 知識庫 > 淺談mysql一張表到底能存多少數(shù)據(jù)

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

熱門標(biāo)簽:怎樣在地圖標(biāo)注銷售區(qū)域 地圖標(biāo)注費(fèi)用是多少 啥是企業(yè)400電話辦理 外呼系統(tǒng)打電話上限是多少 曲靖移動外呼系統(tǒng)公司 電話外呼系統(tǒng)改號 武漢網(wǎng)絡(luò)外呼系統(tǒng)服務(wù)商 南昌三維地圖標(biāo)注 百應(yīng)電話機(jī)器人優(yōu)勢

程序員平時和mysql打交道一定不少,可以說每天都有接觸到,但是mysql一張表到底能存多少數(shù)據(jù)呢?計算根據(jù)是什么呢?接下來咱們逐一探討

知識準(zhǔn)備

數(shù)據(jù)頁

在操作系統(tǒng)中,我們知道為了跟磁盤交互,內(nèi)存也是分頁的,一頁大小4KB。同樣的在MySQL中為了提高吞吐率,數(shù)據(jù)也是分頁的,不過MySQL的數(shù)據(jù)頁大小是16KB。(確切的說是InnoDB數(shù)據(jù)頁大小16KB)。詳細(xì)學(xué)習(xí)可以參考官網(wǎng)我們可以用如下命令查詢到。

mysql> SHOW GLOBAL STATUS LIKE 'innodb_page_size';
+------------------+-------+
| Variable_name  | Value |
+------------------+-------+
| Innodb_page_size | 16384 |
+------------------+-------+
1 row in set (0.00 sec)

今天咱們數(shù)據(jù)頁的具體結(jié)構(gòu)指針等不深究,知道它默認(rèn)是16kb就行了,也就是說一個節(jié)點(diǎn)的數(shù)據(jù)大小是16kb

索引結(jié)構(gòu)(innodb)

mysql的索引結(jié)構(gòu)咱們應(yīng)該都知道,是如下的b+樹結(jié)構(gòu)

通常b+樹非葉子節(jié)點(diǎn)不存儲數(shù)據(jù),只有葉子節(jié)點(diǎn)(最下面一層)才存儲數(shù)據(jù),那么咱們說回節(jié)點(diǎn),一個節(jié)點(diǎn)指的是(對于上圖而言)

每個紅框選中的部分稱為一個節(jié)點(diǎn),而不是說某個元素。了解了節(jié)點(diǎn)的概念和每個節(jié)點(diǎn)的大小為16kb之后,咱們計算mysql能存儲多少數(shù)據(jù)就容易很多了

具體計算方法

根節(jié)點(diǎn)計算

首先咱們只看根節(jié)點(diǎn)

比如我們設(shè)置的數(shù)據(jù)類型是bigint,大小為8b

在數(shù)據(jù)本身如今還有一小塊空間,用來存儲下一層索引數(shù)據(jù)頁的地址,大小為6kb

所以我們是可以計算出來一個數(shù)據(jù)為(8b+6b=14b)的空間(以bigint為例)我們剛剛說到一個數(shù)據(jù)頁的大小是16kb,也就是(161024)b,那么根節(jié)點(diǎn)是可以存儲(161024/(8+6))個數(shù)據(jù)的,結(jié)果大概是1170個數(shù)據(jù)如果跟節(jié)點(diǎn)的計算方法計算出來了,那么接下來的就容易了。

其余層節(jié)點(diǎn)計算

第二層其實(shí)比較容易,因為每個節(jié)點(diǎn)數(shù)據(jù)結(jié)構(gòu)和跟節(jié)點(diǎn)一樣,而且在跟節(jié)點(diǎn)每個元素都會延伸出來一個節(jié)點(diǎn),所以第二層的數(shù)據(jù)量是1170*1170=1368900,問題在于第三層,因為innodb的葉子節(jié)點(diǎn),是直接包含整條mysql數(shù)據(jù)的,如果字段非常多的話數(shù)據(jù)所占空間是不小的,我們這里以1kb計算,所以在第三層,每個節(jié)點(diǎn)為16kb,那么每個節(jié)點(diǎn)是可以放16個數(shù)據(jù)的,所以最終mysql可以存儲的總數(shù)據(jù)為

1170 * 1170 * 16 = 21902400 (千萬級條)

其實(shí)計算結(jié)果與我們平時的工作經(jīng)驗也是相符的,一般mysql一張表的數(shù)據(jù)超過了千萬也是得進(jìn)行分表操作了。

總結(jié)

最后用一張圖片總結(jié)一下今天討論的內(nèi)容,希望您能喜歡

到此這篇關(guān)于淺談mysql一張表到底能存多少數(shù)據(jù)的文章就介紹到這了,更多相關(guān)mysql表存多少數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 使用pymysql查詢數(shù)據(jù)庫,把結(jié)果保存為列表并獲取指定元素下標(biāo)實(shí)例
  • mysql創(chuàng)建存儲過程實(shí)現(xiàn)往數(shù)據(jù)表中新增字段的方法分析
  • Django使用Mysql數(shù)據(jù)庫已經(jīng)存在的數(shù)據(jù)表方法
  • MySQL修改數(shù)據(jù)表存儲引擎的3種方法介紹
  • MySQL動態(tài)創(chuàng)建表,數(shù)據(jù)分表的存儲過程

標(biāo)簽:甘南 錦州 資陽 隨州 黑河 荊州 滄州 吉林

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《淺談mysql一張表到底能存多少數(shù)據(jù)》,本文關(guān)鍵詞  淺談,mysql,一張,表,到底,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《淺談mysql一張表到底能存多少數(shù)據(jù)》相關(guān)的同類信息!
  • 本頁收集關(guān)于淺談mysql一張表到底能存多少數(shù)據(jù)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章