mysql 出现1071错误怎么办


本文摘自PHP中文网,作者coldplay.xixi,侵删。

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

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

该问题是由键值字段长度过长导致。mysql支持数据库表单一键值的最大长度不能超过767字节,超出这个长度即报错(见标题名称)。一般情况下,不会有键值字段的长度会超出该长度。但是需要注意的是,随着全球化进程的加快,数据库表采用UTF-8格式的趋势是越来越明显,这导致varchar类型字段的长度成倍增长,一不小心就容易出现以上问题。

假设存在以下表定义:

1

2

3

4

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教程

以上就是mysql 出现1071错误怎么办的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql导入文件中文乱码怎么办

mysql如何来创建表

mysql怎么查询最新的记录

[mysql] mvcc多版本并发控制实现的事务

mysql模糊查询语句整理集合

mysql多字段唯一约束

navicate连接mysql数据库报错了怎么办

怎么彻底删除mysql服务?

eclipse中如何编写连接mysql数据库的通用文件

mysql查询连续记录方式

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...