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

Abfrageergebnisse nach dem Laden von XML mit fn:string-join in eine Oracle-Tabelle aufteilen

Nun, das ist, was String-Join tun soll:Es verkettet Werte, die mit dem XPath übereinstimmen. Was Sie also suchen, ist eigentlich nur Ihre Abfrage ohne den String-Join. Ich weiß nicht genau, wie Ihr XML aussieht, aber ich würde vorschlagen, eine SQL wie diese zu versuchen:

insert into table_a
(computer_brand,
 owner,
 address,
 serialnumber
)
select
 a.computer_brand,
 a.owner,
 a.address,
 a.serialnumber
from table_xml a,
 xmltable (xmlnamespaces('not mentioned due to security reasons' as "tns"),
 '//tns:Main' passing a.xml_file
 columns
 computer_brand      varchar2(41)  path 'tns:/@computer_brand',
 owner               varchar2(101) path 'tns:/@owner)',
 address             varchar2(101) path 'tns:/@address)',
 serialnumber        varchar2(21)  path 'tns:/serialnumber')
(+) k
where upper(file_name)=upper('xmlfile.xml');