#1071-指定的密钥太长;最大密钥长度为767字节
当我执行以下命令时:
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_cicolumn2 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
回答:
在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限制的改进。
以上是 #1071-指定的密钥太长;最大密钥长度为767字节 的全部内容, 来源链接: utcz.com/qa/408161.html