首页 >数据库 >mysql教程 >为什么我在创建唯一密钥时收到 MySQL 错误 #1071:超过最大密钥长度?

为什么我在创建唯一密钥时收到 MySQL 错误 #1071:超过最大密钥长度?

DDD
DDD原创
2024-12-14 08:04:11245浏览

Why am I getting MySQL Error #1071: Maximum Key Length Exceeded when creating a unique key?

MySQL 错误 #1071:超过最大键长度

向包含 VARCHAR 数据类型列的 MySQL 表添加唯一键约束时,可能会遇到以下错误:

#1071 - Specified key was too long; max key length is 767 bytes

即使 VARCHAR 列的组合长度看起来小于最大值,也会发生此错误键长度,在 MySQL 5.6 及之前版本中为 767 字节。

错误原因

MySQL 5.6 及以下版本中 InnoDB 表的规定前缀限制为 767 字节。这意味着键列前缀的组合长度不能超过此限制。对于MyISAM表,最大键长度为1,000字节。

在提供的示例中,列column1和column2分别具有VARCHAR(20)和VARCHAR(500)数据类型。这意味着总长度为 522 字节,在 767 字节限制以下留有足够的余量。然而,错误消息表明情况并非如此。

解释

错误的原因是MySQL对VARCHAR列使用了可变长度的多字节编码。这意味着 VARCHAR 列中的每个字符都可以由不同数量的字节表示。例如,VARCHAR(20) 列最多可以容纳 20 个字符,但如果采用 UTF-8mb4 等宽字符格式编码,每个字符最多可以占用 3 个字节。

结果,key的实际长度由每列可以存储的字符串的最大可能长度决定。在这种情况下,column1和column2中的字符串的最大可能长度分别为20 3字节= 60字节和500 3字节= 1500字节。总共有 60 1500 = 1560 字节,超过了最大密钥长度 767 字节。

解决方案

要解决此问题,您可以考虑以下解决方案:

  • 减少 VARCHAR 列的最大长度。 对于例如,您可以将 column1 的数据类型更改为 VARCHAR(15)。
  • 使用较短的键前缀。 您可以只使用它的一个子集,而不是对整个 column2 字段进行索引,例如column2(200)。
  • 使用支持更长密钥长度的不同表引擎。 MyISAM表的最大密钥长度为 1,000 字节,这可能足以满足您的要求。
  • 升级到 MySQL 版本 5.7 或更高版本。MySQL 5.7 及更高版本的最大密钥长度为 3072字节,提供了更大的灵活性。

以上是为什么我在创建唯一密钥时收到 MySQL 错误 #1071:超过最大密钥长度?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn