sql >> Base de Datos >  >> RDS >> Oracle

La combinación externa izquierda de Oracle XMLTABLE no devuelve resultados cuando XPath no existe

No necesita varias llamadas a XMLTable, puede mover la selección de elementos a la cláusula de ruta de la columna y tener tres cláusulas de este tipo:

select x.id1, x.id2, x.id3
from tbl t
cross join
  xmltable ('/root'
    passing t.xml_data
    columns id1 varchar2 (100) path 'element[id=1]/data',
       id2 varchar2 (100) path 'element[id=2]/data',
       id3 varchar2 (100) path 'element[id=3]/data'
) x;

ID1   ID2   ID3 
----- ----- -----
abc   def