- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
这是一个奇怪的谜题,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/
我想解析以下 xml 结构: 为了解析这个 element name="?????? 结构,我按以下方式使用 XPath: XPath xPath
我在 OSX 机器上运行 Python 2.7。我正在尝试在 smb 共享上执行 os.walk。 for root, dirnames, filenames in os.walk("./test")
我是一名优秀的程序员,十分优秀!