开发者社区> 问答> 正文

#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_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 来源:stack overflow

展开
收起
保持可爱mmm 2020-05-10 17:03:01 647 0
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限制的改进。来源:stack overflow

    2020-05-10 17:03:19
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载