码迷,mamicode.com
首页 > 数据库 > 详细

让sql语句不排序,按照in语句的顺序返回结果

时间:2015-01-05 16:23:30      阅读:229      评论:0      收藏:0      [点我收藏+]

标签:

有时候我们需要按照in条件里的id顺序输出结果,可sql语句在不加order by的时候是按照asc排序的,下边的sql解决按照in条件顺序的id输出查询结果

mysql写法:

 

SELECT * FROM EVENT WHERE eventId IN(443,419,431,440,420,414,509)  ORDER BY INSTR(‘,443,419,431,440,420,414,509,‘,CONCAT(‘,‘,eventId,‘,‘))

 

 

oracle写法:

 

select name from order where oderid in(111,222,333,444,555,666)order by instr(‘111,222,333,444,555,666‘,orderid)

 

sqlserver写法:

 

Select * From Product Where id in (1,1588,15782,9887,54)  Order By charindex(‘,‘+ id +‘,‘, ‘,1,1588,15782,9887,54,‘)

 
 分享一个SQL,让in的查询结果按顺序返回结果:SELECT * FROM `pd_customgroup` WHERE `gid` in(2732,2734,2733,99758,2735,109264) order by field(gid, 2732,2734,2733,99758,2735,109264)

 

让sql语句不排序,按照in语句的顺序返回结果

标签:

原文地址:http://www.cnblogs.com/dest/p/4203720.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!