欢迎投稿

今日深度:

Oracle 实现 mysql 的 find_in_set 排序!,oraclefind_in

Oracle 实现 mysql 的 find_in_set 排序!,oraclefind_in_set


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"等等则表示相应的数据的指定顺序了



oracle 有没有类似mysql的find_in_set功可以

find_in_set这个函数不错,可惜Oracle中没有,但是我们可以变相应用,同样可以起到相同的效果。

select
decode(teii.item_num,'GMEXIN10484',1,'HXEXIN10472',2,'HXEXIN10471',3,'GMEXIN10487',4,'GMEXIN10483',5) sequence ,
teii.*
from t_exam_item_info teii
where teii.item_num in ( 'GMEXIN10484','HXEXIN10472','HXEXIN10471','GMEXIN10487','GMEXIN10483' )
order by decode(teii.item_num,'GMEXIN10484',1,'HXEXIN10472',2,'HXEXIN10471',3,'GMEXIN10487',4,'GMEXIN10483',5) ;
 

mysql find_in_set 第一个参数可不可以是多个值

FIND_IN_SET(str,strlist)
假如字符串str 在由N 子链组成的字符串列表strlist 中, 则返回值的范围在 1 到 N 之间 。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。 这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。

这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。
 

www.htsjk.Com true http://www.htsjk.com/shujukunews/2928.html NewsArticle Oracle 实现 mysql 的 find_in_set 排序!,oraclefind_in_set 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) b...
评论暂时关闭