在这种特殊情况下,如何使查询仅在完全匹配时才命中:
MONÉ
应该只点击 MONÃE
,而不是 MONÁE
当前在搜索 MONÁE
时要求 * 吐出包含 MONÉE
的行。我的排序规则是 utf8_unicode_ci
- 所以我猜测它允许基于此的命中。有没有办法为特定查询关闭排序规则?在某些情况下,我希望直接击中,而在其他情况下,我希望无论口音如何都能击中。
我认为这是说 COLLATE utf8_bin 的问题,但这似乎在 WHERE IN 查询中使用时会引发错误,例如...
这个有效:
SELECT * FROM `myTable` WHERE (col1,col2) IN ($mySubQuery)
这失败了;
SELECT * FROM `myTable` WHERE (col1,col2) IN ($mySubQuery) COLLATE utf8_bin
这是我可能得到的实际查询的示例(减去排序规则)- 此查询工作正常:
SELECT `bookID`
FROM `books`
WHERE (Author,Title)
IN (("James Author","My Great Life"))
可以在某处输入排序规则吗?以下失败:
SELECT `bookID`
FROM `books`
WHERE (Author,Title)
COLLATE utf8_bin
IN (("James Author","My Great Life"))
感谢您的宝贵时间和帮助。
最佳答案
您需要将COLLATE
规范附加到您正在搜索的每一列,例如:
SELECT * FROM t1 WHERE c1 COLLATE utf8_bin IN('foo', 'bar');
关于mysql - 精确匹配 UTF-8 上的 mysql 查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18801200/