问题
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 重新创建数据库(必须退出重建,重建的时候最好不要指定编码集,我测试的时候指定了UTF-8不成功);
my.cnf配置:
default-storage-engine=INNODB
innodb_large_prefix=on
方法二:
step1:修改数据库参数配置:innodb_large_prefix=on 或者innodb_large_prefix=1
step2:建表指定row format格式为Dynamic或者Compressed:
create table idx_length_test_02
(
id int auto_increment primary key,
name varchar(255)
)
ROW_FORMAT=DYNAMIC default charset utf8mb4;
或者直接修改已存在的表
alter table <表名> row_format=dynamic;
alter table <表名> row_format=compressed;
一般情况下不建议使用这么长的索引,对性能有一定影响;
参考文档:
https://dev.mysql.com/doc/refman/5.5/en/innodb-restrictions.html