当我执行以下命令时:
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
在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
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。