mysql 出现1071错误怎么办

mysql 出现1071错误的解决办法:该问题是由键值字段长度过长导致,mysql支持数据库表单一键值的最大长度不能超过767字节,如果把长度改为255则没有问题,或者不使用utf& C P-8格式也没有问题。

mysql 出现1071错误怎么办

mysql 出现1071错误的解决办法:

该问题是由键值字段长度过长导致。mysql支持数据库表单一` Z O k w l键值的最大长度不能超过767字节,超出这个长度即报错(见标题名称)。一般情况下,不会有键值字段的长度n , 5 C E t $ X p会超出该长u $ W U F T 9 m p度。但是需要注意的是,随着全球化进T _ - v O m u A程的加快,数据库表采用UTF-8格式的趋势是越来越明显,这导致varchar类型字段的长度成倍增长,一不小心就容易出现以上问题。

假设存在? 6 ^以下表定义:

        create table test (
name varchar(256) not null primary key,
age i~ 4 2 6 I & Q - )nt unsigned not null
) engi f z a ` r 1 9ne = InnoDB;

当使用UTF-8格式建立该表时,就会出现如标题所示问题。关键原因是U; C P ;TF-8使用变长 ( B i i D j m编码,最多可能使用3个字节表示表示1个符号。所以W q 6 # x p I 4 A对于上述表中的name字段,其实际长度超出767字节,达到了: . 8 x X 9 / d768字节,问题出: - G ! E现。如果把长度改为W r ! l255(767/3)则没有问题,或者不使用utf-8格式也没有问题。

相关学习推荐:mysql教程

以上就是mysql 出现1071错误怎么办的详细内容。Z I J