在MySQL中,如果我在UTF-8表中创建一个新的VARCHAR(32)
字段,这是否意味着我可以在该字段中存储32字节或32个字符(多字节)的数据?
发布于 2010-11-17 21:03:07
对于高频更新表,最好使用"char“,因为行的总数据长度将是固定的和快速的。Vchaer列使行数据大小动态变化。这对MyISAM不好,但我不知道InnoDB和其他人。例如,如果您有一个非常窄的“类型”列,最好将char(2)与latin1字符集一起使用,以便只占用最小的空间。
发布于 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,但实际上这是导致相同结果的第二个原因。
https://stackoverflow.com/questions/1997540
复制相似问题