首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否可以按OR顺序对mysql查询进行排序

是否可以按OR顺序对mysql查询进行排序
EN

Stack Overflow用户
提问于 2017-03-10 22:23:17
回答 2查看 41关注 0票数 0

我想按照where子句的顺序对查询结果进行排序。

例如,我有这样的查询:

代码语言:javascript
复制
SELECT * 
  FROM config_ban_num 
 WHERE 
     ( adresse_seo LIKE '12-rue-de-rivoli%' 
    OR adresse_seo LIKE '13-rue-de-rivoli%' 
    OR adresse_seo LIKE '11-rue-de-rivoli%' ) 
   AND (postcode='75004')

当我打印结果时,我得到了这样的结果:

代码语言:javascript
复制
11-rue-de-rivoli
12-rue-de-rivoli
13-rue-de-rivoli

我想要关于where子句中的顺序的顺序:

代码语言:javascript
复制
12-rue-de-rivoli
13-rue-de-rivoli
11-rue de rivoli
EN

回答 2

Stack Overflow用户

发布于 2017-03-10 22:26:53

一种选择是使用子查询:

代码语言:javascript
复制
SELECT * FROM (
    SELECT *,
      CASE WHEN adresse_seo LIKE '12-rue-de-rivoli%' THEN 1
           WHEN adresse_seo LIKE '13-rue-de-rivoli%' THEN 2
           WHEN adresse_seo LIKE '11-rue-de-rivoli%' THEN 3
           ELSE 4 END as Position
      FROM config_ban_num 
     WHERE 
         ( adresse_seo LIKE '12-rue-de-rivoli%' 
        OR adresse_seo LIKE '13-rue-de-rivoli%' 
        OR adresse_seo LIKE '11-rue-de-rivoli%' ) 
       AND (postcode='75004')
) SubQuery

ORDER BY Position
票数 1
EN

Stack Overflow用户

发布于 2017-03-10 22:36:33

使用MySQL's FIELD function

代码语言:javascript
复制
SELECT * 
FROM config_ban_num 
WHERE adresse_seo in ('12-rue-de-rivoli%', '13-rue-de-rivoli%', '11-rue-de-rivoli%') 
AND (postcode='75004')
ORDER BY FIELD(adresse_seo, '12-rue-de-rivoli%', '13-rue-de-rivoli%', '11-rue-de-rivoli%')
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42720628

复制
相关文章

相似问题

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