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/
目录
相关文章
|
9月前
|
存储 缓存 关系型数据库
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL的存储引擎是其核心组件之一,负责数据的存储、索引和检索。不同的存储引擎具有不同的功能和特性,可以根据业务需求 选择合适的引擎。本文详细介绍了MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案。
1600 57
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
|
存储 算法
【堆】数据结构堆的实现(万字详解)
【堆】数据结构堆的实现(万字详解)
595 0
|
3月前
|
Java 数据挖掘 调度
Java 多线程创建零基础入门新手指南:从零开始全面学习多线程创建方法
本文从零基础角度出发,深入浅出地讲解Java多线程的创建方式。内容涵盖继承`Thread`类、实现`Runnable`接口、使用`Callable`和`Future`接口以及线程池的创建与管理等核心知识点。通过代码示例与应用场景分析,帮助读者理解每种方式的特点及适用场景,理论结合实践,轻松掌握Java多线程编程 essentials。
220 5
|
3月前
|
存储 关系型数据库 数据库
高性能云盘:一文解析RDS数据库存储架构升级
性能、成本、弹性,是客户实际使用数据库过程中关注的三个重要方面。RDS业界率先推出的高性能云盘(原通用云盘),是PaaS层和IaaS层的深度融合的技术最佳实践,通过使用不同的存储介质,为客户提供同时满足低成本、低延迟、高持久性的体验。
|
8月前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
1471 1
|
8月前
|
Java 测试技术 Spring
Spring Boot随机端口怎么动态扩容?
在Spring Boot中,可以通过`${random.int(2000,8000)}`在配置文件中设置随机端口,确保每次启动时端口不同。此外,还可以通过检测机制确保生成的随机端口未被占用,避免端口冲突。具体实现包括使用`System.setProperty`设置有效随机端口、自定义属性源以及直接设置`server.port=0`让Spring Boot自动选择空闲端口。推荐使用`server.port=0`以简化配置并避免冲突。
132 8
|
SQL 缓存 关系型数据库
mysql性能优化-慢查询分析、优化索引和配置
mysql性能优化-慢查询分析、优化索引和配置
515 1
|
10月前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
190 8
|
11月前
|
Java 调度 UED
深入理解Java中的多线程与并发机制
本文将详细探讨Java中多线程的概念、实现方式及并发机制,包括线程的生命周期、同步与锁机制以及高级并发工具。通过实例代码演示,帮助读者理解如何在Java中有效地处理多线程和并发问题,提高程序的性能和响应能力。
|
安全
常见ip被限制的原因以及解决办法
常见ip被限制的原因以及解决办法
867 0