为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

千巷猫影 2019-08-08 11:09:29
如何在MySql中进行重音敏感搜索我有一个MySQL表与utf8通用ci整理。在表格中,我可以看到两个条目:阿巴德阿巴德我使用的查询如下所示:SELECT *  FROM `words` WHERE `word` = 'abád'查询结果给出了两个单词:阿巴德阿巴德有没有办法表明我只想让MySQL找到重音词?我希望查询只返回阿巴德我也试过这个查询:SELECT *  FROM `words` WHERE BINARY `word` = 'abád'它没有给我任何结果。感谢您的帮助。
查看完整描述

3 回答

?
慕雪6442864

TA贡献1812条经验 获得超5个赞

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

col_name varchar(10) collate utf8_bin

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

WHERE col_name = 'abád' collate utf8_bin


查看完整回答
反对 回复 2019-08-08
?
猛跑小猪

TA贡献1858条经验 获得超8个赞

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

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

SELECT * FROM `words` WHERE LOWER(column) = LOWER('aBád') COLLATE utf8_bin


查看完整回答
反对 回复 2019-08-08
  • 3 回答
  • 0 关注
  • 504 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信