gpt4 book ai didi

mysql - 如何设置 MySQL 以正确处理 unicode 变音符号?

转载 作者:可可西里 更新时间:2023-11-01 08:35:17 62 4
gpt4 key购买 nike

这是一个奇怪的谜题,AFAIK utf8_bin 应该保证每个口音都正确地存储在数据库中,即没有一些奇怪的 ASCII 转换。所以我有这样的表:

DEFAULT CHARSET=utf8 COLLATE=utf8_bin

然而,当我根据 MySQL 尝试比较/查询/任何诸如“Krąków”和“Kraków”之类的条目时,这是相同的字符串。

出于好奇,我也尝试了 utf8_polish,MySQL 声称对于波兰人来说“a”和“±”没有任何区别。

那么如何设置 MySQL 表,以便我可以安全地存储 unicode 字符串,而不会丢失重音符号等?

服务器:MySQL 5.5 + openSUSE 11.4,客户端:Windows 7 + MySQL Workbench 5.2。

更新——创建表

CREATE TABLE `Cities` (
`city_Name` VARCHAR(145) CHARACTER SET utf8 NOT NULL,
PRIMARY KEY (`city_Name`)
) DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

请注意,我不能为列设置一个不同的 utf8_bin,因为整个表都是 utf8_bin,所以实际上列的排序规则重置为默认值。

最佳答案

解决方案的所有功劳都归功于 bobince,所以请为他对我的问题的评论点赞。

这个问题的解决方案有点奇怪,我敢说 MySQL 在这方面已经崩溃了。

所以,假设我用 utf8 创建了一个表,但没有为列做任何事情。后来我意识到我需要严格的字符比较,所以我将表和列的排序规则更改为utf8_bin。解决了吗?

不,现在 MySQL 看到了这一点——表确实是 utf8_bin,但列也是 utf8_bin,这意味着列使用表的 DEFAULT 排序规则。然而 MySQL 没有意识到以前的默认值与当前的默认值不同。因此比较仍然不起作用。

因此,您必须摆脱列的默认值,将其设置为排序规则“family”范围之外的某些外来值(如果“utf8xxx”表示没有其他“utf8xxx”)。一旦它被摇掉,并且你看到在列排序规则中没有说“默认”的条目,你可以设置 utf8_bin,它现在计算为默认值,但由于我们来自非默认排序规则,一切都会按预期启动。

不要忘记在每一步应用更改。

关于mysql - 如何设置 MySQL 以正确处理 unicode 变音符号?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14903067/

62 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com