由官方文档可知,mysql一行最多可以存储65535个字节,mysql5.0以后的版本中,varchar类型的长度是指的可以存储的字符个数,比如varchar(10),则最多可以存储10个字符。

utf-8编码下

一个汉字占用三个字节,一个字母或数字占用1个字节,字段的长度需要用1个字节(长度小于256时)或两个字节(长度大于等于用256时)表示,空值NULL需要用1个字节表示,因此varchar类型的字段在允许为空的情况下最大可以存储(65535-2-1)/3=21844个字符,不为空时最大可以存储(65535-2)/3=21844.3333个字符。

gbk编码下

一个汉字占用两个字节,一个字母或数字占用1个字节,字段的长度需要用1个字节(长度小于256时)或两个字节(长度大于等于用256时)表示,空值NULL需要用1个字节表示,因此varchar类型的字段在允许为空的情况下最大可以存储(65535-2-1)/2=32766个字符,不允许为空时最大可以存储(65535-2)/2=32766.5个字符。

latin1编码下

一个汉字占用两个字节,字段的长度需要用1个字节(长度小于256时)或两个字节(长度大于等于用256时)表示,空值NULL需要用1个字节表示,因此varchar类型的字段在允许为空的情况下最大可以存储(65535-2-1)/2=32766个汉字,不允许为空时最大可以存储(65535-2)/2=32766.5个汉字。

一个字母或数字占用1个字节,字段的长度需要用1个字节(长度小于256时)或两个字节(长度大于等于用256时)表示,空值NULL需要用1个字节表示,,因此varchar类型的字段在允许为空的情况下最大可以存储65535-2-1=65532个字母或数字,不允许为空时最大可以存储65535-2=65533个字母或数字。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐