Oracle
 sql >> Base de données >  >> RDS >> Oracle

Diviser les résultats de la requête après le chargement de XML avec fn:string-join dans une table Oracle

Eh bien, c'est ce que string-join est censé faire :il concatène les valeurs correspondant à XPath. Donc, en fait, ce que vous recherchez n'est que votre requête sans la jointure de chaîne. Je ne sais pas exactement à quoi ressemble votre XML, mais je suggérerais d'essayer un SQL comme celui-ci :

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');