面試提問(wèn)mysql一張表到底能存多少數(shù)據(jù)
前言
程序員平時(shí)和mysql打交道一定不少,可以說(shuō)每天都有接觸到,但是mysql一張表到底能存多少數(shù)據(jù)呢?計(jì)算根據(jù)是什么呢?接下來(lái)咱們逐一探討
1、知識(shí)準(zhǔn)備
1.1、數(shù)據(jù)頁(yè)
在操作系統(tǒng)中,我們知道為了跟磁盤(pán)交互,內(nèi)存也是分頁(yè)的,一頁(yè)大小4KB。同樣的在MySQL中為了提高吞吐率,數(shù)據(jù)也是分頁(yè)的,不過(guò)MySQL的數(shù)據(jù)頁(yè)大小是16KB。(確切的說(shuō)是InnoDB數(shù)據(jù)頁(yè)大小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ù)頁(yè)的具體結(jié)構(gòu)指針等不深究,知道它默認(rèn)是16kb就行了,也就是說(shuō)一個(gè)節(jié)點(diǎn)的數(shù)據(jù)大小是16kb
1.2、索引結(jié)構(gòu)(innodb)
mysql的索引結(jié)構(gòu)咱們應(yīng)該都知道,是如下的b+樹(shù)結(jié)構(gòu)

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

每個(gè)紅框選中的部分稱為一個(gè)節(jié)點(diǎn),而不是說(shuō)某個(gè)元素。了解了節(jié)點(diǎn)的概念和每個(gè)節(jié)點(diǎn)的大小為16kb之后,咱們計(jì)算mysql能存儲(chǔ)多少數(shù)據(jù)就容易很多了
2、具體計(jì)算方法
2.1、根節(jié)點(diǎn)計(jì)算
首先咱們只看根節(jié)點(diǎn)
比如我們?cè)O(shè)置的數(shù)據(jù)類型是bigint,大小為8b

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

所以我們是可以計(jì)算出來(lái)一個(gè)數(shù)據(jù)為(8b+6b=14b)的空間(以bigint為例) 我們剛剛說(shuō)到一個(gè)數(shù)據(jù)頁(yè)的大小是16kb,也就是(16*1024)b,那么根節(jié)點(diǎn)是可以存儲(chǔ)(16*1024/(8+6))個(gè)數(shù)據(jù)的,結(jié)果大概是1170個(gè)數(shù)據(jù) 如果跟節(jié)點(diǎn)的計(jì)算方法計(jì)算出來(lái)了,那么接下來(lái)的就容易了。
2.2、其余層節(jié)點(diǎn)計(jì)算
第二層其實(shí)比較容易,因?yàn)槊總€(gè)節(jié)點(diǎn)數(shù)據(jù)結(jié)構(gòu)和跟節(jié)點(diǎn)一樣,而且在跟節(jié)點(diǎn)每個(gè)元素都會(huì)延伸出來(lái)一個(gè)節(jié)點(diǎn),所以第二層的數(shù)據(jù)量是1170*1170=1368900,問(wèn)題在于第三層,因?yàn)閕nnodb的葉子節(jié)點(diǎn),是直接包含整條mysql數(shù)據(jù)的,如果字段非常多的話數(shù)據(jù)所占空間是不小的,我們這里以1kb計(jì)算,所以在第三層,每個(gè)節(jié)點(diǎn)為16kb,那么每個(gè)節(jié)點(diǎn)是可以放16個(gè)數(shù)據(jù)的,所以最終mysql可以存儲(chǔ)的總數(shù)據(jù)為
1170 * 1170 * 16 = 21902400 (千萬(wàn)級(jí)條)
其實(shí)計(jì)算結(jié)果與我們平時(shí)的工作經(jīng)驗(yàn)也是相符的,一般mysql一張表的數(shù)據(jù)超過(guò)了千萬(wàn)也是得進(jìn)行分表操作了。
3、總結(jié)
最后用一張圖片總結(jié)一下今天討論的內(nèi)容,希望您能喜歡

以上就是面試提問(wèn)mysql一張表到底能存多少數(shù)據(jù)的詳細(xì)內(nèi)容,更多關(guān)于mysql一張表能存多少數(shù)據(jù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
MySQL 數(shù)據(jù)庫(kù)設(shè)計(jì)復(fù)習(xí)筆記及項(xiàng)目實(shí)戰(zhàn)
參考的數(shù)據(jù)庫(kù)文檔主要有:目前國(guó)內(nèi)的常見(jiàn)的PHP系統(tǒng)的數(shù)據(jù)庫(kù)2010-03-03
MySQL 計(jì)算時(shí)間差(分鐘)的三種實(shí)現(xiàn)
本文主要介紹了MySQL 計(jì)算時(shí)間差(分鐘)的三種實(shí)現(xiàn),包含TIMEDIFF函數(shù),TIMESTAMPDIFF函數(shù)和算術(shù)運(yùn)算符這三種方法,具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07
MySQL查詢優(yōu)化的5個(gè)實(shí)用技巧
這篇文章主要介紹了MySQL查詢優(yōu)化的5個(gè)實(shí)用技巧,從數(shù)據(jù)類型、字符集、子查詢等角度分析了MySQL查詢優(yōu)化的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-12-12
MySQL 表字段太多超長(zhǎng)問(wèn)題解決方案
在設(shè)計(jì)MySQL數(shù)據(jù)庫(kù)時(shí),常遇到表字段超長(zhǎng)問(wèn)題,這是由字段數(shù)量過(guò)多或字段定義過(guò)長(zhǎng)引起的,MySQL對(duì)字段數(shù)量和行大小有嚴(yán)格限制,超過(guò)限制將無(wú)法正常操作,本文就來(lái)介紹一下解決方法,感興趣的可以了解一下2024-10-10
clickhouse復(fù)雜時(shí)間格式的轉(zhuǎn)換方式
這篇文章主要介紹了clickhouse復(fù)雜時(shí)間格式的轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
Mysql用戶權(quán)限分配實(shí)戰(zhàn)項(xiàng)目詳解
用戶是數(shù)據(jù)庫(kù)的使用者和管理者,MySQL通過(guò)用戶的設(shè)置來(lái)控制數(shù)據(jù)庫(kù)操作人員的訪問(wèn)與操作范圍,這篇文章主要給大家介紹了關(guān)于Mysql用戶權(quán)限分配實(shí)戰(zhàn)項(xiàng)目的相關(guān)資料,需要的朋友可以參考下2023-12-12
mysql導(dǎo)入sql文件命令和mysql遠(yuǎn)程登陸使用詳解
這篇文章主要介紹了mysql導(dǎo)入sql文件命令和mysql遠(yuǎn)程登陸使用詳解,需要的朋友可以參考下2014-04-04

