InnoDB限制

简介: InnoDB 限制 Limits MySQL

限制

以下限制基于MySQL 8.0.x

  1. 单表只能有1017个列
  2. 单表最多有64个二级索引
  3. 在使用DYNAMIC或COMPRESSED row format时索引前缀长度最大为3072个字节
  4. 一个组合索引的最大列数为16

如果超过了16个列会会报错:

ERROR 1070 (42000): Too many key parts specified; max 16 parts allowed
  1. 最大行大小略微小于页面的一半

例如:InnoDB的默认innodb_page_size是16KB,那么行大小在8000字节左右。但是对于InnoDB页面大小在64KB时,最大行大小在16000字节左右。对于包含LongBLOB和LONGTEXT类型的列最大行大小不应该超过4GB,对于BLOB和TEXT类型的列,最大行大小不应该超过4GB。
不包括变成列,因为边长列会分页存储。

  1. MySQL强制一行所有列的数据大小不能超过65535个字节,尽管InnoDB支持的最大行大小超过了65535个字节。
  2. 在一些老的操作系统中,单个文件的大小不能超过2GB,那么这个会限制InnoDB的文件空间。在这些操作系统上,可以配置file-per-table为1让每张表有自己的表空间。
  3. InnoDB日志文件的最大组合大小为512GB。
  4. 表空间最小在10MB左右。最大的表空间依赖于InnoDB 页面大小配置。
InnoDB页面大小 最大表空间大小
4KB 16TB
8KB 32TB
16KB 64TB
32KB 128TB
64KB 256TB

为什么有这个限制?
因为InnoDB表空间的基本单位是页面,每个页面有一个页号,这个页号也称为页偏移;页号是一个32位的整数,所以一个表空间最多有2的32次方个页面,将页面个数乘以页面大小就是这个表空间的最大大小,例如:页面大小为16KB也是2的14次方,那么64TB= 16KB * 2^32,其他的依次替换页面大小即可。

  1. InnoDB最大支持2^32个表空间。
  2. 共享表空间最大支持2^32个表。
  3. 表空间文件路径加文件名在Windows上不能超过MAX_PATH定义的最大长度。在Windows10以前,MAX_PATH定义的长度是260个字符。在Windows10的1607版本中 ,普通Win32文件和目录函数的MAX_PATH限制被移除。

参考

  1. https://dev.mysql.com/doc/refman/8.0/en/innodb-limits.html
  2. https://blog.jcole.us/2013/01/03/the-basics-of-innodb-space-file-layout/
目录
相关文章
|
存储 缓存 关系型数据库
InnoDB的特点
InnoDB是MySQL数据库的存储引擎之一
145 0
|
25天前
|
存储 缓存 关系型数据库
什么是InnoDB
【10月更文挑战第17天】什么是InnoDB
|
25天前
|
存储 关系型数据库 MySQL
什么是MyISAM和InnoDB
【10月更文挑战第17天】什么是MyISAM和InnoDB
31 0
|
6月前
|
存储 监控 关系型数据库
InnoDB
【5月更文挑战第14天】InnoDB
52 3
|
11月前
|
存储 关系型数据库 MySQL
InnoDB和MyISAM存储引擎对比
InnoDB和MyISAM存储引擎对比 相同点:都是B+索引,不清楚B+索引的可以看上一篇
69 1
|
SQL 存储 关系型数据库
第20章_Myisam与InnoDB
第20章_Myisam与InnoDB
40 0
|
存储 安全 关系型数据库
【Innodb 和mylsam存储引擎】
【Innodb 和mylsam存储引擎】
110 0
|
关系型数据库 MySQL 数据库
MyISAM和InnoDB区别
MyISAM和InnoDB区别
MyISAM和InnoDB区别
|
存储 SQL 关系型数据库
有了InnoDB,Memory存储引擎还有意义吗?(上)
两个group by 语句都用了order by null,为什么使用内存临时表得到的语句结果里,0这个值在最后一行;而使用磁盘临时表得到的结果里,0这个值在第一行?
123 0
有了InnoDB,Memory存储引擎还有意义吗?(上)
|
存储 关系型数据库 MySQL
InnoDB存储引擎中
InnoDB存储引擎中
113 0