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个字母或数字。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值