Oracle
 sql >> Datenbank >  >> RDS >> Oracle

String Wort für Wort mit SQL umkehren

XML-basierte Version, um die Definition einer eigenen Funktion zu vermeiden; benötigt 11g für listagg() :

select listagg(word, ' ') within group (order by rn desc) as reversed
from (
  select word, rownum as rn
  from xmltable('for $i in ora:tokenize($STR, " ") return $i'
    passing 'Hello World! I Love StackOverflow' as str
    columns word varchar2(4000) path '.'
  )
);

REVERSED                               
----------------------------------------
StackOverflow Love I World! Hello        

Die XMLTable() führt die Tokenisierung durch und weist eine Zeilennummer zu:

select rownum as rn, word
from xmltable('for $i in ora:tokenize($STR, " ") return $i'
  passing 'Hello World! I Love StackOverflow' as str
  columns word varchar2(4000) path '.'
);

        RN WORD               
---------- --------------------
         1 Hello                
         2 World!               
         3 I                    
         4 Love                 
         5 StackOverflow        

Die listagg() setzt es dann in umgekehrter Reihenfolge wieder zusammen.