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

今天在设计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,这点需要特别注意。

你可能感兴趣的:(数据库,mysql,文档)