您的位置:首页 > 数据库 > MySQL

MySQL: ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes

2012-02-26 23:29 555 查看
今天在设计mysql的数据库字段的时候,建表过程中一直提示MySQL:
ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes。开始没有弄明白是为什么,因为在默认情况下面,mysql对于varchar的类型的长度限制在0到65535之间,后来仔细的查看了一下针对该字段的其他属性,发现将其设置成了unique,如果将unique属性去掉,则不会报这样的错误提示,符合官方文档所说的支持65535字节的长度限制。

个人怀疑将字段设置成为unique后mysql会自动将唯一性索引建立在该字段上,,而对于维护唯一性索引又会存在着系统开销,所以就会出现这种问题,一方面提供唯一性索引,另外避免维护过长的索引造成的开销问题。
另外在mysql中还有一个问题必须注意,那就是utf-8默认是一个字符占用三个字节,对于GBK这些编码方式占用的是2个字节,因此如果你的字符集编码格式为utf-8的话,那么767/3=255个字符,只能支持到255个字符,而非767,这点需要特别注意。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐