面试提问mysql一张表到底能存多少数据


Posted in MySQL onMarch 13, 2022

前言

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

1、知识准备

1.1、数据页

在操作系统中,我们知道为了跟磁盘交互,内存也是分页的,一页大小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就行了,也就是说一个节点的数据大小是16kb

1.2、索引结构(innodb)

mysql的索引结构咱们应该都知道,是如下的b+树结构

面试提问mysql一张表到底能存多少数据

通常b+树非叶子节点不存储数据,只有叶子节点(最下面一层)才存储数据,那么咱们说回节点,一个节点指的是(对于上图而言)

面试提问mysql一张表到底能存多少数据

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

2、具体计算方法

2.1、根节点计算

首先咱们只看根节点

比如我们设置的数据类型是bigint,大小为8b

面试提问mysql一张表到底能存多少数据

在数据本身如今还有一小块空间,用来存储下一层索引数据页的地址,大小为6kb

面试提问mysql一张表到底能存多少数据

所以我们是可以计算出来一个数据为(8b+6b=14b)的空间(以bigint为例) 我们刚刚说到一个数据页的大小是16kb,也就是(16*1024)b,那么根节点是可以存储(16*1024/(8+6))个数据的,结果大概是1170个数据 如果跟节点的计算方法计算出来了,那么接下来的就容易了。

2.2、其余层节点计算

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

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

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

3、总结

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

面试提问mysql一张表到底能存多少数据

以上就是面试提问mysql一张表到底能存多少数据的详细内容,更多关于mysql一张表能存多少数据的资料请关注三水点靠木其它相关文章!

MySQL 相关文章推荐
mysql死锁和分库分表问题详解
Apr 16 MySQL
mysql 如何获取两个集合的交集/差集/并集
Jun 08 MySQL
MySQL千万级数据表的优化实战记录
Aug 04 MySQL
SQL实现LeetCode(197.上升温度)
Aug 07 MySQL
MyBatis 动态SQL全面详解
Oct 05 MySQL
MySQL窗口函数的具体使用
Nov 17 MySQL
MySQL数据库⾼可⽤HA实现小结
Jan 22 MySQL
一条 SQL 语句执行过程
Mar 17 MySQL
提高系统的吞吐量解决数据库重复写入问题
Apr 23 MySQL
Mysql 数据库中的 redo log 和 binlog 写入策略
Apr 26 MySQL
Mysql 一主多从的部署
May 20 MySQL
数据设计之权限的实现
Aug 05 MySQL
MySQL的索引你了解吗
面试中老生常谈的MySQL问答集锦夯实基础
浅谈如何保证Mysql主从一致
MySQL数据库如何给表设置约束详解
Mar 13 #MySQL
Mysql外键约束的创建与删除的使用
Mar 03 #MySQL
解决MySQL添加新用户-ERROR 1045 (28000)的问题
Mar 03 #MySQL
MySQL之MyISAM存储引擎的非聚簇索引详解
You might like
JAVA/JSP学习系列之六
2006/10/09 PHP
php实现约瑟夫问题的方法小结
2015/03/23 PHP
phpinfo()中Loaded Configuration File(none)的解决方法
2017/01/16 PHP
PHP实现的折半查找算法示例
2017/12/19 PHP
php+js实现点赞功能的示例详解
2020/08/07 PHP
JavaScript 编程引入命名空间的方法
2007/06/29 Javascript
js里的prototype使用示例
2010/11/19 Javascript
读jQuery之六 缓存数据功能介绍
2011/06/21 Javascript
制作jquery遮罩层效果导航菜单代码分享
2013/12/25 Javascript
javaScript对文字按照拼音排序实现代码
2013/12/27 Javascript
如何动态的导入js文件具体该怎么实现
2014/01/14 Javascript
JS小游戏之极速快跑源码详解
2014/09/25 Javascript
JavaScript控制图片加载完成后调用回调函数的方法
2015/03/20 Javascript
javascript实现链接单选效果的方法
2015/05/13 Javascript
JavaScript正则表达式中的ignoreCase属性使用详解
2015/06/16 Javascript
纯JavaScript 实现flappy bird小游戏实例代码
2016/09/27 Javascript
angular2系列之路由转场动画的示例代码
2017/11/09 Javascript
JS实现在线ps功能详解
2019/07/31 Javascript
[00:34]TI7不朽珍藏III——纯金地穴编织者饰品展示
2017/07/15 DOTA
Python 实现购物商城,含有用户入口和商家入口的示例
2017/09/15 Python
浅谈numpy数组的几种排序方式
2017/12/15 Python
Python+OpenCV目标跟踪实现基本的运动检测
2018/07/10 Python
python生成带有表格的图片实例
2019/02/03 Python
使用python将多个excel文件合并到同一个文件的方法
2019/07/09 Python
python能做什么 python的含义
2019/10/12 Python
python打印直角三角形与等腰三角形实例代码
2019/10/20 Python
详解mac python+selenium+Chrome 简单案例
2019/11/08 Python
Python版中国省市经纬度
2020/02/11 Python
flask项目集成swagger的方法
2020/12/09 Python
Nike加拿大官网:Nike.com (CA)
2019/04/09 全球购物
金融行业职业生涯规划范文
2014/01/17 职场文书
实习推荐信
2014/05/10 职场文书
2014年工程师工作总结
2014/11/25 职场文书
2016年党员学习廉政准则心得体会
2016/01/20 职场文书
详解SQL的窗口函数
2022/04/21 Oracle
类和原型的设计模式之复制与委托差异
2022/07/07 Javascript