码迷,mamicode.com
首页 > 数据库 > 详细

mysql 索引过长1071-max key length is 767 byte

时间:2019-04-11 11:58:22      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:配置   arch   specified   char   utf8   问题   mysql 索引   my.cnf   tab   

问题

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

mysql 索引过长1071-max key length is 767 byte

标签:配置   arch   specified   char   utf8   问题   mysql 索引   my.cnf   tab   

原文地址:https://blog.51cto.com/13476134/2377030

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!