sql >> Databasteknik >  >> RDS >> Oracle

Omvänd sträng ord för ord med SQL

XML-baserad version för att undvika att definiera din egen funktion; kräver 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        

XMLTable() gör tokeniseringen och tilldelar ett radnummer:

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        

listagg() sätter sedan ihop det i omvänd ordning.



  1. Oracle SQL:Hur man använder mer än 1000 objekt i en IN-klausul

  2. SCHEMA() Funktion i MySQL

  3. MySQL Snabbtips:Använd kommandot DROP USER

  4. Hur får man den senaste posten i varje grupp med GROUP BY?