Oracle 實現 mysql 的 find_in_set 排序!,oraclefind_in_set

來源:互聯網
上載者:User

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。 這個函數在第一個參數包含一個逗號(‘,’)時將無法正常運行。

這個函數在第一個參數包含一個逗號(‘,’)時將無法正常運行。
 

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.