varchar(xx)表示多少个字符

在MySql数据库中,如果某个值得字段设置为varchar(30)代表的是几个字符呢?
首先,varchar(20)代表的是可以在数据库中存储20个字节的长度,如果存储数据超出了20个字节,多余的部分将不会被存储。
那到底表示存储多少个字符呢,这要看采取的编码规则是什么。
如果是utf8编码
如果存储的字符要用1个字节表示,存储下来的二进制数据举例为0 0101101 ,其中的第一位的0标识这个字符需要用1个字节表示,剩余的位7位才是表示这个字符,此时也就是说,1字节的最多只能表示128个字符;
如果存储的字符要用2个字节表示,存储下来二进制数据举例为110 10110 10 111000,其中的前面的110 就标识这个字符需要用2个字节表示,中间的那个10 是用来连接前后两端字符的,剩余的5+6位才是表示这个字符,此时也就是说,2字节的最多只能表示2048(2的11次方)个字符,此时也不难看出来,2048个字符是完全无法将汉字表示完全的。
如果存储的字符要用3个字节,存储下来的二进制数据举例为1110 1001 10 111101 10 110000,同理,最前面的1110就标识这个字符需要用3个字节表示,两个10 也是用来连接字符的,剩余的4+6+6为才是编码位,此时也就是说 ,3字节的最多能表示65536(2的16次方)个字符,这个就可以表示汉字了.
综上所述:varchar(30)若是表示ASC码表中的字符,则可以表示30个,若是中文可以表示10个.

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值