素材牛VIP会员
mysql中varchar(M),M的最大值问题
 ai***ft  分类:SQL代码  人气:736  回帖:1  发布于6年前 收藏

mysql中varchar(M),M的最大值问题
1.mysql每行不能超过65535字节
2.如果某列允许为null,则实际存储最大值为65535-1字节
3.varchar类型所占的最大字节取决于其它列所占的字节,需要65535减去这些
4.varchar本身需要1-2个字节来记录该列的内容长度,超过255个字符需要2个字节

utf8编码下,一般一个汉字占3个字节,英文一个字节,韩语似乎是1个字节,日语似乎也是3个字节

假设,只有一个varchar类型的列,且不允许为null
varchar(M)中的M,为什么不能超过 (65535-2)/3
M是所代表的字符数
mysql怎么就知道你一定存中文呢?
还是说mysql规定:只要是utf8,就按这个公式(确切的说是方式)去计算呢
谢谢诸位了

 标签:varcharutf-8mysql

讨论这个帖子(1)垃圾回帖将一律封号处理……

Lv6 码匠
蜗***跑 产品经理 6年前#1

在MySQL 5.0之前,M代表字节数,而之后的版本代表字符数,所以这里有点历史遗留问题。也就是为什么会别扭的要用公式去算。

 文明上网,理性发言!   😉 阿里云幸运券,戳我领取