varchar(xx)表示多少个字符

本文详细解析了在MySql数据库中,varchar(30)字段在不同编码规则下(如utf8)所能存储的字符数量。通过深入探讨1字节、2字节和3字节编码的原理,揭示了该字段在ASCII和中文字符存储上的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在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个.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值