utf-8 - mysql中varchar(M),M的最大值问题
巴扎黑
巴扎黑 2017-04-17 13:48:38
0
1
809

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,就按这个公式(确切的说是方式)去计算呢
谢谢诸位了

巴扎黑
巴扎黑

全員に返信(1)
大家讲道理

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

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート