Mysql5.6:Specified key was too long
Specified key was too long
- 错误
- 原因
- 解决方案
- 参考
错误
create table: Specified key was too long; max key length is 767 bytes
原因
数据库表采用utf8编码,其中varchar(255)的column进行了唯一键索引
而mysql默认情况下单个列的索引不能超过767位(不同版本可能存在差异)
于是utf8字符编码下,255*3 byte 超过限制
解决方案
1 使用innodb
引擎;
2 启用innodb_large_prefix
选项,将约束项扩展至3072byte;
3 重新创建
数据库;
my.cnf配置:
default-storage-engine=INNODB
innodb_large_prefix=on
参考
https://stackoverflow.com/questions/1814532/1071-specified-key-was-too-long-max-key-length-is-767-bytes
还没有评论,来说两句吧...