Mysql中的varchar 如何设置最大长度 10

才开始接触mysql用途是这样的Java操作中对某样东西转为base64但是我不确定这个结果的长度是多少能否直接把varchar给设置成最大可用长度... 才开始接触mysql
用途是这样的
Java操作中 对某样东西转为base64
但是 我不确定这个结果的长度是多少
能否直接把varchar给设置成最大可用长度
展开
 我来答
v11003049
2019-05-05 · 超过16用户采纳过TA的回答
知道答主
回答量:49
采纳率:0%
帮助的人:9.2万
展开全部
mysql varchar(50) 不管中文 还是英文 都是存50个的

MySQL5的文档,其中对varchar字段类型这样描述:varchar(m) 变长字符串。M 表示最大列长度。M的范围是0到65,535。(VARCHAR的最大实际长度由最长的行的大小和使用的字符集确定,最大有效长度是65,532字节)。

为何会这般变换?真是感觉MySQL的手册做的太不友好了,因为你要仔细的继续往下读才会发现这段描述:MySQL

5.1遵从标准SQL规范,并且不删除VARCHAR值的尾部空格。VARCHAR保存时用一个字节或两个字节长的禅猜埋前缀+数据。如果VARCHAR列声明的长度大于255,长度前缀是两个字节。

好了,貌似懂了一点。但具体他说的长度大于255时使用2个字节长度前缀,小学减法题:65535 - 2 = 65533啊。不知道这贺蚂兆丛些大牛如何计算的,暂且保留疑问吧?

注:我测试了一下使用UTF8编码,varchar的最大长度为21854字节。

在mysql 5.0.45版本,数据库编码utf8下进行测试:varchar最长定义为21785。也就是说不论字母、数字、汉字,只能放21785个。
追问
那么 我在不确定我需要存入的数据的长度情况下
我把varchar设置为65533
那么他所占用的空间怎么算呢
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式