Qualcuno sa come recuperare i valori di <ZIPCODE>
e <CITY>
utilizzando PL/SQL? Ho seguito un tutorial sulla rete, tuttavia, è in grado di recuperare i nomi degli elementi, ma non i loro valori. Qualcuno di voi sa quale sembra essere il problema? Ho già consultato Google (ben tenuto segreto di Internet) su questo, ma senza fortuna :(Recupera il valore di un elemento xml in Oracle PL SQL
<Zipcodes>
<mappings Record="4">
<STATE_ABBREVIATION>CA</STATE_ABBREVIATION>
<ZIPCODE>94301</ZIPCODE>
<CITY>Palo Alto</CITY>
</mappings>
</Zipcodes>
ecco il codice di esempio:
-- prints elements in a document
PROCEDURE printElements(doc DBMS_XMLDOM.DOMDocument) IS
nl DBMS_XMLDOM.DOMNodeList;
n DBMS_XMLDOM.DOMNode;
len number;
BEGIN
-- get all elements
nl := DBMS_XMLDOM.getElementsByTagName(doc, '*');
len := DBMS_XMLDOM.getLength(nl);
-- loop through elements
FOR i IN 0 .. len - 1 LOOP
n := DBMS_XMLDOM.item(nl, i);
testr := DBMS_XMLDOM.getNodeName(n) || ' ' || DBMS_XMLDOM.getNodeValue(n);
DBMS_OUTPUT.PUT_LINE (testr);
END LOOP;
DBMS_OUTPUT.PUT_LINE ('');
END printElements;
Personalmente preferisco utilizzare XMLType e utilizzare la funzione Estrai per ottenerli tramite XPath. per esempio. 'myxml.Extract ('/ Zipcodes/mappings/ZIPCODE/text()');' - deve essere più semplice di camminare sul DOM. –