在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个.
varchar(xx)表示多少个字符
最新推荐文章于 2025-03-15 06:00:00 发布