Varchar(20)中的20代表的是字符还是字节

Varchar在MySQL5.03之前的最大长度为255字节,之后为65535字节。Varchar(255)可存储约255字节的字符串,长度受中英文字符影响。在4.0版本中,Varchar(50)对应50字节,而在5.0及以上版本,它指50个字符。对于UTF-8编码的汉字,每个汉字占3字节。Varchar的长度在不同版本中按字节或字符定义,影响存储汉字的数量。

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

Varchar在5.03之前可以是最大255字节,然后是最大65535字节

Varchar(255)可以存储大约255字节的字符串,并且字符数随中英文之间的空间占用而变化

在4.0版本下,Varchar(50)指50字节。如果你存储utf8汉字,你只能存储16个(每个汉字3个字节)5.0以上的版本,varchar(50)指的是50个字其实,最好的办法就是在自己的数据库里建一个表,试试能放多少个汉字。现在MySQL5.0已经上市。Varchar(50)可以存储50个汉字,取决于版本:4.0以下,Varchar(100)表示存储utf8汉字时的100字节,5.0或以上版本只能存储33个(每个汉字3字节)。Varchar(100)表示100个字符。无论存储数字、字母或utf8汉字(每个汉字3字节),都可以存储100个字符。

Varchar不管什么版本最大长度都是按字节定义的,但是在5.0版本之前括号中的数字是字节,在5.0版本之后括号中的数字是字符

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值