首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何根据何处条件获得查询的优先输出?

如何根据何处条件获得查询的优先输出?
EN

Stack Overflow用户
提问于 2018-07-10 06:21:45
回答 1查看 29关注 0票数 2

我有一个查询,如下所示

代码语言:javascript
复制
SELECT * FROM vehicle_type_master order by standard_volume asc

得出以下结果:

代码语言:javascript
复制
Vehicle_Type_ID    standard_volume
 TATA ACE            20
  407                30
 20 FT               40

因此,可能会出现以下条件,查询如下

一审:

代码语言:javascript
复制
SELECT * FROM vehicle_type_master where Vehicle_Type_ID    = '407'

因此对于这个查询,所需的结果应该如下所示

代码语言:javascript
复制
Vehicle_Type_ID    standard_volume
  407                30
TATA ACE             20
 20 FT               40

二审:

代码语言:javascript
复制
SELECT * FROM vehicle_type_master where Vehicle_Type_ID    = '20 FT'

因此对于这个查询,所需的结果应该如下所示

代码语言:javascript
复制
Vehicle_Type_ID    standard_volume
  20 FT                 40
TATA ACE                20
  407                   30

因此,无论哪种条件存在,应该放在第一位的条件和其他行应该按照standard_volume asc显示。

感谢你的任何帮助

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-10 06:27:10

可以将CASE WHEN与多个ORDER BY结合使用。

代码语言:javascript
复制
SELECT * 
FROM vehicle_type_master  
ORDER BY (CASE WHEN Vehicle_Type_ID  = '407' then 0 else 1 end) ,
standard_volume asc

SQLfiddle:http://sqlfiddle.com/#!9/1b3907/10

使用IFORDER BY的最简单方法

代码语言:javascript
复制
SELECT * 
FROM vehicle_type_master  
ORDER BY IF(Vehicle_Type_ID ='20 FT',0,1),standard_volume asc

方形小提琴:http://sqlfiddle.com/#!9/1b3907/9

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

https://stackoverflow.com/questions/51258404

复制
相关文章

相似问题

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