我无法加入某些表,因为有些表/行是utf8_general_ci,有些是utf8_turkish_ci。因此,我不得不将土耳其人改名为将军,将其转换为将军并最终使用它。但我想知道,如果我将原始表从土耳其语转换为通用语,我的应用程序会发生什么?我在PHP中使用MySQL。
这是最初的错误:Illegal mix of collations (utf8_general_ci,IMPLICIT) and (utf8_turkish_ci,IMPLICIT) for operation '='
答案 0 :(得分:1)
您的列数据使用字符集存储。在这种情况下,似乎是utf8。
当您对这些列进行操作(例如,进行相等比较或排序)时,MySQL会使用排序规则。每列都有一个默认排序规则,它从表的默认排序规则继承。
索引将列的默认排序规则烘焙到它们中,以便它们可以有效运行。
您可以进行由排序规则限定的相等比较。例如,在JOIN
中,您可以指定
ON (turkish.village_name COLLATE utf8_general_ci) = euro.village_name
或者
ON turkish.village_name = (euro.village_name COLLATE utf8_turkish_ci)
这应该消除你的非法混合排序,而不要求你改变你的桌子。这可以帮助您避免数据库更改。但要注意,使用COLLATE
限定符可以打败索引的使用。如果你有一个大表,而你依赖索引来提高性能,那么这可能是无益的。
那么,如果更改表以更改默认排序规则会发生什么?
ORDER BY
结果将不正确。但是,您可以通过在COLLATE
子句中指定ORDER BY
修饰符来解决此问题。
ORDER BY (euro.village_name COLLATE utf8_turkish_ci)