MySQL的表上限

Posted caicoffee

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL的表上限相关的知识,希望对你有一定的参考价值。

一、行数的上限

1、官方文档

There is a limit of (2^32)^2 (1.844E+19) rows in a MyISAM table.

这是mysql的行数的理论上限,但实际上是达不到的

2、myisam_data_pointer_size 限制

实际行数上限还受myisam_data_pointer_size限制,64位的mysql的myisam_data_pointer_size通常是6,即48位,行数是2^48 - 1 = 281474976710655。

3、存储空间的限制

表的存储空间大小限制(Storage limits):256TB。

所以只要知道最小一行需要的空间,就能求出最多能存的记录数。

二、列数的限制

MySQL对于每个表具有4096个列的硬限制,但给定表的有效最大值可能较少。精确的列限制取决于几个因素:

  1. 表的最大行大小限制列的数量(可能是大小),因为所有列的总长度不能超过此大小。请参阅行大小限制

  2. 单个列的存储要求限制了适合给定最大行大小的列数。某些数据类型的存储要求取决于存储引擎,存储格式和字符集等因素。请参见数据类型存储要求

  3. 存储引擎可能会施加限制表列计数的额外限制。例如, InnoDB每个表的限制为1017列。请参见对InnoDB表的限制有关其他存储引擎的信息,请参见替代存储引擎

  4. 每个表都有一个.frm包含表定义的文件。该定义以可能影响表中允许的列数的方式影响此文件的内容。请参见.frm文件结构引起的限制

以上是关于MySQL的表上限的主要内容,如果未能解决你的问题,请参考以下文章

Day909.MySQL 不同的自增 id 达到上限以后的行为 -MySQL实战

部分代码片段

linux中怎么查看mysql数据库版本

sql MySQL的使用极限时不限制上限

MySQL到底能有多少个字段

MySQL不同版本的默认最大连接数和上限