mysql一张表到底能存多少数据?

前言

程序员平时和mysql打交道必定很多,能够说天天都有接触到,可是mysql一张表到底能存多少数据呢?计算根据是什么呢?接下来我们逐一探讨mysql

知识准备

数据页

在操做系统中,咱们知道为了跟磁盘交互,内存也是分页的,一页大小4KB。一样的在MySQL中为了提升吞吐率,数据也是分页的,不过MySQL的数据页大小是16KB。(确切的说是InnoDB数据页大小16KB)。详细学习能够参考官网 咱们能够用以下命令查询到。程序员

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

今天我们数据页的具体结构指针等不深究,知道它默认是16kb就好了,也就是说一个节点的数据大小是16kbsql

索引结构(innodb)

mysql的索引结构我们应该都知道,是以下的b+树结构 一般b+树非叶子节点不存储数据,只有叶子节点(最下面一层)才存储数据,那么我们说回节点,一个节点指的是(对于上图而言)数据结构

每一个红框选中的部分称为一个节点,而不是说某个元素。 了解了节点的概念和每一个节点的大小为16kb以后,我们计算mysql能存储多少数据就容易不少了学习

具体计算方法

根节点计算

首先我们只看根节点spa

好比咱们设置的数据类型是bigint,大小为8b 在数据自己现在还有一小块空间,用来存储下一层索引数据页的地址,大小为6kb操作系统

因此咱们是能够计算出来一个数据为(8b+6b=14b)的空间(以bigint为例) 咱们刚刚说到一个数据页的大小是16kb,也就是(161024)b,那么根节点是能够存储(161024/(8+6))个数据的,结果大概是1170个数据 若是跟节点的计算方法计算出来了,那么接下来的就容易了。3d

其他层节点计算

第二层其实比较容易,由于每一个节点数据结构和跟节点同样,并且在跟节点每一个元素都会延伸出来一个节点,因此第二层的数据量是1170*1170=1368900,问题在于第三层,由于innodb的叶子节点,是直接包含整条mysql数据的,若是字段很是多的话数据所占空间是不小的,咱们这里以1kb计算,因此在第三层,每一个节点为16kb,那么每一个节点是能够放16个数据的,因此最终mysql能够存储的总数据为指针

1170 * 1170 * 16 = 21902400 (千万级条)code

其实计算结果与咱们平时的工做经验也是相符的,通常mysql一张表的数据超过了千万也是得进行分表操做了。

总结

最后用一张图片总结一下今天讨论的内容,但愿您能喜欢

相关文章
相关标签/搜索