首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在MySql中执行区分重音的搜索

如何在MySql中执行区分重音的搜索
EN

Stack Overflow用户
提问于 2009-02-01 13:42:49
回答 9查看 68.2K关注 0票数 75

我有一个包含utf8通用ci排序规则的MySQL表。在表格中,我可以看到两个条目:

放弃

阿巴德

我使用的查询如下所示:

代码语言:javascript
复制
SELECT *  FROM `words` WHERE `word` = 'abád'

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

放弃

阿巴德

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

阿巴德

我也尝试过这个查询:

代码语言:javascript
复制
SELECT *  FROM `words` WHERE BINARY `word` = 'abád'

它没有给我任何结果。谢谢你的帮助。

EN

回答 9

Stack Overflow用户

回答已采纳

发布于 2009-02-01 17:01:12

如果对该字段搜索总是区分重音,那么将该字段的排序规则声明为utf8_bin (这将比较utf8编码的字节是否相等),或者使用区分重音字符和非重音字符的特定于语言的排序规则。

代码语言:javascript
复制
col_name varchar(10) collate utf8_bin

如果搜索通常是不区分重音的,但您想为此搜索破例,请尝试;

代码语言:javascript
复制
WHERE col_name = 'abád' collate utf8_bin
票数 97
EN

Stack Overflow用户

发布于 2010-08-24 00:54:23

在我的版本(MySql 5.0)中,没有任何utf8字符集collate可用于不区分大小写、区分重音的搜索。utf8唯一区分重音的排序规则是utf8_bin。但是,它也区分大小写。

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

代码语言:javascript
复制
SELECT * FROM `words` WHERE LOWER(column) = LOWER('aBád') COLLATE utf8_bin
票数 16
EN

Stack Overflow用户

发布于 2011-02-25 04:57:37

为了便于将来参考,MySQL的bug是http://bugs.mysql.com/bug.php?id=19567

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

https://stackoverflow.com/questions/500826

复制
相关文章

相似问题

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