当前位置:数据库 > MySQL >>

#1071 - Specified key was too long; max key length is 1000 bytes

出现这个问题,主要去查看你的索引,看看是不是给太长的字段增加了索引

例如我给 title varchar(300) 做了一个索引

然后不仅提示错误,还速度慢,新增id自增长 不连续 转换数据表格式也不行

最后把 title改成 varchar(20)  就对了,不建议给太长的字段做所以,没意义


#1071 -Specified key was too long; max key length is 767 bytes

#1071 - Specified key was too long; max key length is 1000 bytes
 
1,mysql导入同事发的sql文件报如下错误:1071 -Specified key was too long; max key length is 767 bytes
2,这是因为数据库表采用utf8编码,其中varchar(255)的column进行了唯一键索引
而mysql默认情况下单个列的索引不能超过767位(不同版本可能存在差异)
于是utf8字符编码下,255*3 byte 超过限制

3,解决方法为:

(1) 使用innodb引擎;

(2) 启用innodb_large_prefix选项,将约束项扩展至3072byte;
(3) 重新创建数据库;

my.cnf配置:
default-storage-engine=INNODB
innodb_large_prefix=on
4,一般情况下不建议使用这么长的索引,对性能有一定影响;
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,