单列索引的长度的限制
(5.6里面默认不能超过767bytes,5.7不超过3072bytes):
起因是256×3-1=767。这个3是字符最大占用空间(utf8)。但是在5.5以后,开始支持4个字节的uutf8。255×4>767, 于是增加了一个参数叫做 innodb_large_prefix
# 256的由来: 只是因为char最大是255,所以以前的程序员以为一个长度为255的index就够用了,所以设置这个256.历史遗留问题。 --- by 阿里-丁奇
在MySQL5.6里默认 innodb_large_prefix=0 限制单列索引长度不能超过767bytes
官网文档:https://dev.mysql.com/doc/refman/5.6/en/innodb-parameters.html#sysvar_innodb_large_prefix
注意:
在MySQL5.6里面,设置了innodb_large_prefix=ON、innodb_file_format=barracuda、innodb_file_per_table=ON ,且Innodb表的存储格式为 DYNAMIC 或 COMPRESSED,则前缀索引最多可包含3072个字节,前缀索引也同样适用。
如下2例:
> create table t_DYNAMIC(
a int PRIMARY key not null AUTO_INCREMENT,
b varchar(3072))
character set=latin1
ROW_FORMAT=DYNAMIC ;
> alter table t_DYNAMIC ad