国内最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2
您当前位置:首页 > 互联网 > Oracle 实现 mysql 的 find_in_set 排序!

Oracle 实现 mysql 的 find_in_set 排序!

来源:程序员人生   发布时间:2014-10-14 00:17:16 阅读次数:2145次

oracle 实现类似MYSQL的 find_in_set 排序,函数 decode:

select * from tb_info_game where gameid in(23,20,19,26,18) order by decode(gameid,23,1,20,2,18,3,26,4,1009,5)
by default7#zbphp.com



参考CDSN的帖子:http://topic.csdn.net/t/20060124/08/4532718.html

提问:
------------------------------------------------------------------------------------
SQL语句中   
   
  order   by     可以按照指定的顺序排序否   
   
  比如   记录中   某字段值       NCH     HCH       ACS       TWN....   
   
  我让记录按照如上的顺序排列,OK   ?


回答:
-------------------------------------------------------------------------------------
ORDER   BY   DECODE(col,'NCH','1','HCH','2','ACS','3','TWN','4',col)   
   
  这种情况估计只能这样了


说明:
"col"表示要排序的列名称
'NCH','HCH','ACS'等等表示排序的列中的具体数据
"1","2","3"等等则表示相应的数据的指定顺序了


生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠
程序员人生
------分隔线----------------------------
分享到:
------分隔线----------------------------
关闭
程序员人生