首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在mySQL中使用WHERE子句并在两列中搜索字符串

在mySQL中使用WHERE子句并在两列中搜索字符串
EN

Stack Overflow用户
提问于 2015-12-16 12:18:33
回答 1查看 28关注 0票数 0

我有一个查询,在两个字段( FIELD_IMPORTANT和FIELD_2 )中搜索“string”。

我想要有结果;

如果在FIELD_IMPORTANT中找到“string”,那么将结果排序,记录的顶部是FIELD_IMPORTANT中的“string”,然后其他的.

有可能吗?

到目前为止,我有以下几点:

代码语言:javascript
复制
SELECT
expert.expert_name, naf_add.FIELD_IMPORTANT, naf_level_5.FIELD_2,
ROUND(AVG(expert_rating.rating_global)) AS avg_rating_global

FROM naf_nomenclature

LEFT JOIN naf_add ON naf_add.naf_add_naf_level_5_code = naf_nomenclature.level_5_code
INNER JOIN naf_level_5 ON naf_level_5.level_5_code = naf_nomenclature.level_5_code
INNER JOIN expert ON expert.expert_level_5_code = naf_nomenclature.level_5_code
LEFT JOIN expert_rating ON expert_rating.rating_expert_id = expert.expert_id


WHERE 
naf_add.FIELD_IMPORTANT  LIKE '%elec%' OR
naf_level_5.FIELD_2 LIKE '%elec%'

GROUP BY expert.expert_name

ORDER BY fword DESC, avg_rating_global DESC
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-16 12:23:35

可以在order by中使用表达式。

代码语言:javascript
复制
order by (naf_add.FIELD_IMPORTANT LIKE '%elec%') desc,
         fword, avg_rating_global

MySQL将布尔表达式视为数值上下文中的整数,其中"0“表示false,"1”表示true。因此,当表达式为true时,第一个键的值为"1“。desc把这些放在第一位。

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

https://stackoverflow.com/questions/34311863

复制
相关文章

相似问题

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