首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在where子句mysql中精确匹配utf8中的单词

在where子句mysql中精确匹配utf8中的单词
EN

Stack Overflow用户
提问于 2015-03-23 16:47:47
回答 2查看 1.8K关注 0票数 2

我有这样的疑问:

代码语言:javascript
复制
SELECT * FROM category_keyword  WHERE keyword = 'cho'

此查询是返回结果keyword ={ cho , chợ , chờ , chợ ...}。我只希望结果是关键字= 'cho‘(而不是'chợ,chờ.’)。我该怎么做?表的排序是utf8_unicode_ci

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-03-23 17:02:16

使用utf8排序规则,cho确实等于chờ。如果要将其作为二进制进行比较:

代码语言:javascript
复制
SELECT * FROM category_keyword WHERE keyword = CONVERT('cho' USING binary)
票数 4
EN

Stack Overflow用户

发布于 2015-03-24 00:03:21

将列的排序规则更改为utf8_bin。这比使用转换更好,因为它允许使用索引。但是,如果您有时需要utf8_bin (精确匹配),有时需要utf8_unicode_ci (大小写折叠和重音剥离),那么您就不走运了,性能也不太好。

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

https://stackoverflow.com/questions/29215763

复制
相关文章

相似问题

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