Jestem nowy w Oracle i mam - być może trywialny - problem z wyborem. (Używam wersji Oracle 10g Express Edition).Oracle 10g: Wyodrębnij dane (wybierz) z XML (typ CLOB)
Mam DB z CLOB pola: mytab.xml Ta kolumna mają XML jak poniżej:
<?xml version="1.0" encoding="iso-8859-1"?>
<info>
<id> 954 </id>
<idboss> 954 </idboss>
<name> Fausto </name>
<sorname> Anonimo </sorname>
<phone> 040000000 </phone>
<fax> 040000001 </fax>
</info>
Próbuję zrobić „proste” Wybierz, aby uzyskać, na przykład, wartość znacznika "faks". Ale mam mały problem i nie jestem w stanie zrozumieć mojego błędu. Na przykład:
select extract(xml, '//fax').getStringVal() from mytab;
ORA-00932: inconsistent datatypes: expected - got
select extract(xmltype(xml), '//fax').getStringVal() from mytab;
ORA-06502: PL/SQL: numeric or value error
ORA-06512: at "SYS.XMLTYPE", line 254
Próbowałem również z "wartością wyrywkową", ale mam te same problemy. gdzie nie mam racji?
jeszcze: ORA-06502: PL/SQL: numeryczny lub wartość błędu ORA-06512 : w "SYS.XMLTYPE" linia 254 ORA-06512: w linii 1 – mymark
Niestety ... tak, twoja odpowiedź działa idealnie! W poprzednim przypadku mam xml null ^^! – mymark
W 11g mogę opuścić '.getStringVal()' -part out. Nie mam pojęcia o 10g, ponieważ nie mam tutaj żadnych. – user272735