本文主要是介绍mysql varchar存储字符数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
由官方文档可知,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个字母或数字。
这篇关于mysql varchar存储字符数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!