原因
数据库表采用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
一般情况下不建议使用这么长的索引,对性能有一定影响;
这是网上的一遍文章的解决办法,但是我没有修改成功
下面我参考了一些其他的文章并结合自己的操作一步步去确定问题在哪。
有同学问到InnoDB的索引长度问题,简单说几个tips。
关于3072
大家经常碰到InnoDB单列索引长度不能超过767bytes,实际上联合索引还有一个限制是3072。
Sql代码 收藏代码
mysql> CREATE TABLE tb (
-> a varchar(255) DEFAULT NULL,
-> b varchar(255) DEFAULT NULL,
-> c varchar(255) DEFAULT NULL,
-> d varchar(255) DEFAULT NULL,
-> e varchar(255) DEFAULT NULL,
-> KEY a (a,b,c,d,e)<