一尘不染

#1071-指定的密钥太长;最大密钥长度为767字节

mysql

当我执行以下命令时:

ALTER TABLE `mytable` ADD UNIQUE (
`column1` ,
`column2`
);

我收到此错误消息:

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

有关column1和column2的信息:

column1 varchar(20) utf8_general_ci
column2  varchar(500) utf8_general_ci

我认为varchar(20)只需要21个字节,而varchar(500)只需要501个字节。因此,总字节数是522,少于767。那么为什么收到错误消息?

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

阅读 423

收藏
2020-05-17

共1个答案

一尘不染

在MySQL版本5.6(及更早版本)中,InnoDB表的前缀限制为767个字节。MyISAM表的长度为1,000字节。在MySQL 5.7及更高版本中,此限制已增加到3072字节。

您还必须注意,如果在utf8mb4编码的大char或varchar字段上设置索引,则必须将767字节(或3072字节)的最大索引前缀长度除以4,得到191。这是因为utf8mb4字符的最大长度为四个字节。对于utf8字符,它将是三个字节,导致最大索引前缀长度为254。

您必须采取的一种选择是将下限放在VARCHAR字段上。

另一个选择(根据对此问题响应)是获取列的子集而不是整个列,即:

ALTER TABLE `mytable` ADD UNIQUE ( column1(15), column2(200) );

进行调整,您需要获取要应用的密钥,但是我想知道是否值得对有关该实体的数据模型进行检查,以查看是否存在可以使您实现预期业务规则而又不违反MySQL限制的改进。

2020-05-17