面试提问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 可扩展设计的基本原则
May 14 MySQL
MySQL的安装与配置详细教程
Jun 26 MySQL
MySQL系列之六 用户与授权
Jul 02 MySQL
MySQL中几种插入和批量语句实例详解
Sep 14 MySQL
MySQL分库分表详情
Sep 25 MySQL
mysql主从复制的实现步骤
Oct 24 MySQL
MySQL中CURRENT_TIMESTAMP的使用方式
Nov 27 MySQL
你真的会用Mysql的explain吗
Mar 31 MySQL
Mysql表数据比较大情况下修改添加字段的方法实例
Jun 28 MySQL
mysql sock文件存储了什么信息
Jul 15 MySQL
MySQL中的 inner join 和 left join的区别解析(小结果集驱动大结果集)
May 08 MySQL
MySQL的索引你了解吗
面试中老生常谈的MySQL问答集锦夯实基础
浅谈如何保证Mysql主从一致
MySQL数据库如何给表设置约束详解
Mar 13 #MySQL
Mysql外键约束的创建与删除的使用
Mar 03 #MySQL
解决MySQL添加新用户-ERROR 1045 (28000)的问题
Mar 03 #MySQL
MySQL之MyISAM存储引擎的非聚簇索引详解
You might like
PHP中比较时间大小实例
2014/08/21 PHP
php利用header函数下载各种文件
2016/08/24 PHP
利用PHP将图片转换成base64编码的实现方法
2016/09/13 PHP
Thinkphp实现短信验证注册功能
2016/10/18 PHP
thinkPHP中钩子的使用方法实例分析
2017/11/16 PHP
浅谈laravel 5.6 安装 windows上使用composer的安装过程
2019/10/18 PHP
自己动手开发jQuery插件教程
2011/08/25 Javascript
javaScript arguments 对象使用介绍
2013/10/18 Javascript
PHP结合jQuery实现红蓝投票功能特效
2015/07/22 Javascript
AngularJS基础 ng-keypress 指令简单示例
2016/08/02 Javascript
Bootstrap源码解读网格系统(3)
2016/12/22 Javascript
CheckBox多选取值及判断CheckBox选中是否为空的实例
2017/10/31 Javascript
vue组件间通信六种方式(总结篇)
2019/05/15 Javascript
Vue2.x通用条件搜索组件的封装及应用详解
2019/05/28 Javascript
详解Vue中CSS样式穿透问题
2019/09/12 Javascript
nodejs一个简单的文件服务器的创建方法
2019/09/13 NodeJs
JavaScript 自定义html元素鼠标右键菜单功能
2019/12/02 Javascript
[01:38]DOTA2第二届亚洲邀请赛中国区预选赛出线战队晋级之路
2017/01/17 DOTA
[40:03]Liquid vs Optic 2018国际邀请赛淘汰赛BO3 第一场 8.21
2018/08/22 DOTA
Android应用开发中Action bar编写的入门教程
2016/02/26 Python
Python操作Redis之设置key的过期时间实例代码
2018/01/25 Python
Python 统计字数的思路详解
2018/05/08 Python
python 文本单词提取和词频统计的实例
2018/12/22 Python
从列表或字典创建Pandas的DataFrame对象的方法
2019/07/06 Python
pycharm配置安装autopep8自动规范代码的实现
2021/03/02 Python
HTML5实现视频直播功能思路详解
2017/11/16 HTML / CSS
美国和加拿大房车出售在线分类广告:RVT.com
2018/04/23 全球购物
迪士尼法国在线商店:shopDisney FR
2020/12/03 全球购物
介绍一下代理模式(Proxy)
2014/10/17 面试题
乳制品整治工作方案
2014/05/29 职场文书
法制宣传标语
2014/06/23 职场文书
人生遥控器观后感
2015/06/11 职场文书
python使用pygame创建精灵Sprite
2021/04/06 Python
解决pytorch 损失函数中输入输出不匹配的问题
2021/06/05 Python
Python中seaborn库之countplot的数据可视化使用
2021/06/11 Python
JAVA API 实用类 String详解
2021/10/05 Java/Android