如何在MySql中进行重音敏感搜索

Chr*_*ris 60 mysql utf-8

我有一个MySQL表与utf8通用ci整理.在表格中,我可以看到两个条目:

阿巴德
阿巴德

我使用的查询如下所示:

SELECT *  FROM `words` WHERE `word` = 'abád'
Run Code Online (Sandbox Code Playgroud)

查询结果给出了两个单词:

阿巴德
阿巴德

有没有办法表明我只想让MySQL找到重音词?我希望查询只返回

阿巴德

我也试过这个查询:

SELECT *  FROM `words` WHERE BINARY `word` = 'abád'
Run Code Online (Sandbox Code Playgroud)

它没有给我任何结果.感谢您的帮助.

小智 86

如果您对该字段的搜索始终是重音敏感的,则将字段的排序规则声明为utf8_bin(将比较utf8编码字节的相等性)或使用特定于语言的排序规则来区分重音和非字符串 - 有气味的人物.

col_name varchar(10) collate utf8_bin
Run Code Online (Sandbox Code Playgroud)

如果搜索通常不区分重音,但您想为此搜索设置例外,请尝试;

WHERE col_name = 'abád' collate utf8_bin
Run Code Online (Sandbox Code Playgroud)

  • @User尝试使用`collat​​e utf8mb4_bin`代替. (4认同)
  • @OMA查找字符集和整理DB,表和列,所有都应该是相同的才能正常工作 (3认同)
  • 这也可以使用LIKE通配符运算符``WHERE CONVERT(field_name USING latin1),如'%á%'COLLATE utf8_bin` (3认同)

Dav*_*vid 13

在我的版本(MySql 5.0)中,没有任何utf8字符集整理可用于不区分大小写,重音敏感的搜索.utf8唯一的重音敏感分类是utf8_bin.但它也是区分大小写的.

我的工作是使用这样的东西:

SELECT * FROM `words` WHERE LOWER(column) = LOWER('aBád') COLLATE utf8_bin
Run Code Online (Sandbox Code Playgroud)

  • 然后,您应该使用utf8mb4_bin。 (4认同)
  • `#1253 - COLLATION'utf8_bin'对CHARACTER SET'utf8mb4'无效 (3认同)

Rob*_*air 6

接受的答案很好,但请注意,您可能必须使用 COLLATE utf8mb4_bin 代替!

\n\n
WHERE col_name = 'ab\xc3\xa1d' collate utf8mb4_bin\n
Run Code Online (Sandbox Code Playgroud)\n\n

上面修复了如下错误:

\n\n
\n

MySQL 说:文档 1253 - COLLATION 'utf8_bin' 对于\n 字符集 'utf8mb4' 无效

\n
\n