首页
学习
活动
专区
工具
TVP
发布

和MySQL -8
EN

Stack Overflow用户
提问于 2010-01-04 12:41:38
回答 2查看 62.5K关注 0票数 91

在MySQL中,如果我在UTF-8表中创建一个新的VARCHAR(32)字段,这是否意味着我可以在该字段中存储32字节或32个字符(多字节)的数据?

EN

回答 2

Stack Overflow用户

发布于 2010-11-17 21:03:07

对于高频更新表,最好使用"char“,因为行的总数据长度将是固定的和快速的。Vchaer列使行数据大小动态变化。这对MyISAM不好,但我不知道InnoDB和其他人。例如,如果您有一个非常窄的“类型”列,最好将char(2)与latin1字符集一起使用,以便只占用最小的空间。

票数 1
EN

Stack Overflow用户

发布于 2017-09-21 02:38:17

如果您使用latin1编码(例如使用PHP语言)连接到数据库以将PHP字符串保存在MySQL UTF8列中,那么您将使用双UTF8编码。

如果UTF8字符串$s长度为32个字符,但长度为64个字节,并且列为VARCHAR(32) UTF8,则双重编码将字符串$s转换为64个字符长度的UTF8字符串,该字符串在数据库中将被截断为其对应于$s的32个第一个字节的32个第一个字符。您可能最终会认为MySQL 5的行为类似于MySQL 4,但实际上这是导致相同结果的第二个原因。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1997540

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档