码迷,mamicode.com
首页 > 数据库 > 详细

MySQL的表上限

时间:2018-07-24 11:19:50      阅读:303      评论:0      收藏:0      [点我收藏+]

标签:man   innodb   dev   mit   data   .com   table   tar   pointer   

一、行数的上限

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的表上限

标签:man   innodb   dev   mit   data   .com   table   tar   pointer   

原文地址:https://www.cnblogs.com/caicoffee/p/9358697.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!