mysql单个表可以储存多少内容(浅谈mysql一张表到底能存多少数据)
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就行了,也就是说一个节点的数据大小是16kb
索引结构(innodb)
mysql的索引结构咱们应该都知道,是如下的b+树结构
通常b+树非叶子节点不存储数据,只有叶子节点(最下面一层)才存储数据,那么咱们说回节点,一个节点指的是(对于上图而言)
每个红框选中的部分称为一个节点,而不是说某个元素。了解了节点的概念和每个节点的大小为16kb之后,咱们计算mysql能存储多少数据就容易很多了
具体计算方法
根节点计算
首先咱们只看根节点
比如我们设置的数据类型是bigint,大小为8b
在数据本身如今还有一小块空间,用来存储下一层索引数据页的地址,大小为6kb
所以我们是可以计算出来一个数据为(8b+6b=14b)的空间(以bigint为例)我们刚刚说到一个数据页的大小是16kb,也就是(161024)b,那么根节点是可以存储(161024/(8+6))个数据的,结果大概是1170个数据如果跟节点的计算方法计算出来了,那么接下来的就容易了。
其余层节点计算
第二层其实比较容易,因为每个节点数据结构和跟节点一样,而且在跟节点每个元素都会延伸出来一个节点,所以第二层的数据量是1170*1170=1368900,问题在于第三层,因为innodb的叶子节点,是直接包含整条mysql数据的,如果字段非常多的话数据所占空间是不小的,我们这里以1kb计算,所以在第三层,每个节点为16kb,那么每个节点是可以放16个数据的,所以最终mysql可以存储的总数据为
1170 * 1170 * 16 = 21902400 (千万级条)
其实计算结果与我们平时的工作经验也是相符的,一般mysql一张表的数据超过了千万也是得进行分表操作了。
总结
最后用一张图片总结一下今天讨论的内容,希望您能喜欢
到此这篇关于浅谈mysql一张表到底能存多少数据的文章就介绍到这了,更多相关mysql表存多少数据内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
原文链接:https://www.cnblogs.com/xuehao/p/14421795.html
- mysql快速创建索引(MySQL创建高性能索引的全步骤)
- mysql各种锁详解(MySQL 查看事务和锁情况的常用语句分享)
- MySql开启远程连接
- mysql 查询语法常见问题(MySQL 异常有这一篇就够了!)
- pythonmysql使用教程(Python异步操作MySQL示例使用aiomysql)
- mysql添加注释视图(mysql创建表添加字段注释的实现方法)
- 用mysql语句写python学生管理系统(Python基于mysql实现学生管理系统)
- mysql三种查询方式(MySQL查询学习之基础查询操作)
- mysql创建数据库基本指令(MySql 新建用户与数据库的实际操作步骤)
- MySQL DATE_FORMAT()用法
- mysql把重复数据删掉(mysql查找删除重复数据并只保留一条实例详解)
- mysql数据库触发器(MySQL中使用游标触发器的方法)
- mysqltruncate(MYSQL中Truncate的用法详解)
- mysql binlog如何查看(MySQL binlog_ignore_db 参数的具体使用)
- mysql分区表的优缺点(MySQL数据表分区策略及优缺点分析)
- mysql操作时间的函数(一篇文章搞定Mysql日期时间函数)
- 每天都吃水果的好处(每天吃水果的好处与功效)
- 苹果15价格(苹果15价格512g官网)
- 春节放假几天(春节放假几天2023法定几天)
- 今天 3月13日,31年前,一个英雄少年感动了中国(今天3月13日31年前)
- 你好,新成理人丨成都理工大学2019级新生开学典礼隆重举行(新成理人丨成都理工大学2019级新生开学典礼隆重举行)
- 这部民警编演的红色话剧,讲述了一个不断追寻的故事(这部民警编演的红色话剧)
热门推荐
- vscode报错提示框(关于在vscode使用webpack指令显示"因为在此系统中禁止运行脚本"问题)
- php面对对象的三大特性(php中对象引用和复制实例分析)
- sqlserver触发器循环条件(SQL Server 利用触发器对多表视图进行更新的实现方法)
- WCF NetTcpBinding 绑定
- mvc中Scripts.Render、Styles.Render
- 如何查看本机docker的安装目录(使用rpm安装指定版本docker1.12.6的详细步骤)
- input的autocomplete="off"属性
- mysql显示所有数据库语句(MySQL数据库自动补全命令的三种方法)
- python3循环使用教程(Python3.5常见内置方法参数用法实例详解)
- 移动端文字过多显示省略号
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9