首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >MySQL中不区分重音的搜索查询

MySQL中不区分重音的搜索查询
EN

Stack Overflow用户
提问于 2011-12-28 00:51:50
回答 3查看 28.7K关注 0票数 25

有没有办法让搜索查询的重音不敏感?

列和表的排序规则是utf8_polish_ci,我不想更改它们。

示例单词: toruń

select * from pages where title like '%torun%'

它找不到"toruń“。我该怎么做呢?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-12-28 05:31:24

您可以在运行时在sql查询中更改排序规则,

...where title like '%torun%' collate utf8_general_ci

但要注意,在运行时动态更改排序规则会放弃mysql使用索引的可能性,因此在大型表上的性能可能会很糟糕。

或者,您可以将列复制到另一列,例如searchable_title,但更改其排序规则。实际上,做这种类型的事情是很常见的,在这种情况下,您复制数据,但其格式略有不同,并针对特定的工作负载/目的进行了优化。您可以使用触发器作为保持重复列同步的好方法。如果被索引,这个方法有可能执行得很好。

注意-确保你的数据库真的有这些字符,而不是html实体。此外,连接的字符集也很重要。上面假设它被设置为utf8,例如,通过像set names utf8这样的set names

如果不是,则需要文字值的introducer

...where title like _utf8'%torun%' collate utf8_general_ci

当然,单引号中的值实际上必须是utf8编码的,即使查询的其余部分不是。

票数 29
EN

Stack Overflow用户

发布于 2011-12-28 04:46:06

这在极端情况下不起作用,但请尝试将列排序规则更改为UFT8 utf8_unicode_ci。然后,重音字符将与其非重音字符相同。

票数 8
EN

Stack Overflow用户

发布于 2011-12-28 05:39:11

你可以试试SOUNDEX:

http://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_soundex

这将根据两个字符串的发音对它们进行比较。但这显然带来了更多的结果。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8647080

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档