Mysql5.6:Specified key was too long

我不是女神ヾ 2023-08-17 16:49 137阅读 0赞

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配置:

  1. default-storage-engine=INNODB
  2. innodb_large_prefix=on

参考

https://stackoverflow.com/questions/1814532/1071-specified-key-was-too-long-max-key-length-is-767-bytes

发表评论

表情:
评论列表 (有 0 条评论,137人围观)

还没有评论,来说两句吧...

相关阅读