MySQL 1071错误解决办法
2013-11-10 17:20
302 查看
今天在使用mysql时,又遇到了如博文标题所示的问题,以前针对该问题未进行记录,今天特意进行说明存档。
该问题是由键值字段长度过长导致。mysql支持数据库表单一键值的最大长度不能超过767字节,超出这个长度即报错(见标题名称)。一般情况下,不会有键值字段的长度会超出该长度。但是需要注意的是,随着全球化进程的加快,数据库表采用UTF-8格式的趋势是越来越明显,这导致varchar类型字段的长度成倍增长,一不小心就容易出现以上问题。
假设存在以下表定义:
create table test (
name varchar(256) not null primary key,
age int unsigned not null
) engine = InnoDB;
当使用UTF-8格式建立该表时,就会出现如标题所示问题。关键原因是UTF-8使用变长编码,最多可能使用3个字节表示表示1个符号。所以对于上述表中的name字段,其实际长度超出767字节,达到了768字节,问题出现。如果把长度改为255(767/3)则没有问题,或者不使用utf-8格式也没有问题。
相关文章推荐
- MySQL 1071错误解决办法
- MySQL 1071错误解决办法
- MySQL 1071错误解决办法
- MySQL 1071错误解决办法
- MySQL 1071错误解决办法
- mysql的"1067"错误正确解决办法
- MySql 数据库导入"Unknown command '\n'."错误解决办法
- mysql导入数据时提示 USING BTREE 相关错误解决办法
- 2005-Unknown MySQL server host 'localhost' 错误解决办法
- ubuntu上在使用c/c++连接mysql时,出现undefined reference错误解决办法
- mysql导入数据时 USING BTREE 错误解决办法
- mysql安装错误解决办法
- 安装mysql Install/Remove of the Service Denied!错误的解决办法
- mysql导入数据时 USING BTREE 错误解决办法
- MYSQL 错误 :Out of resources when opening file './datagather/mx_domain#P#p178.MYD' (Errcode: 24) 解决办法
- MySQL错误“Specified key was too long; max key length is 1000 bytes”的解决办法
- Windows下安装MySql后,出现的错误解决办法
- mysql错误1067的解决办法
- 安装mysql时提示apply security setting 错误的解决办法
- MySQL 1366 错误解决办法