2011-02-03 60 views
10

Soy nuevo en Oracle y tengo, tal vez trivial, un problema en una selección. (Estoy usando Oracle 10g Express Edition).Oracle 10g: Extraer datos (seleccionar) de XML (tipo CLOB)

Tengo una base de datos con un campo CLOB: mytab.xml Esta columna tiene un XML como esto:

<?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> 

que estoy tratando de hacer un 'simple' selecciono para obtener, por ejemplo, el valor de la etiqueta 'fax'. Pero tengo un problema y no puedo entender mi error. Por ejemplo:

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 

He intentado también con 'extractvalue', pero tengo los mismos problemas. donde estoy equivocado al hacer esto?

Respuesta

27

Tal vez puedas probar:

select xmltype(t.xml).extract('//fax/text()').getStringVal() from mytab t 
+0

todavía no: ORA-06502: PL/SQL: error numérico o valor ORA-06512: en "SYS.XMLTYPE", línea 254 ORA-06512: en la línea 1 – mymark

+0

Lo siento ... sí, ¡su respuesta funciona a la perfección! En el caso anterior, tengo xml null ^^! – mymark

+0

En 11g puedo dejar '.getStringVal()' -part out. No tengo idea de 10g ya que no tengo ninguno aquí. – user272735

3

Trate de usar xmltype.createxml(xml).

igual que en,

select extract(xmltype.createxml(xml), '//fax').getStringVal() from mytab; 

que trabajó para mí.

Si desea mejorar o manipular aún más.

Pruebe algo como esto.

Select * 
from xmltable(xmlnamespaces('some-name-space' as "ns", 
            'another-name-space' as "ns1", 
          ), 
        '/ns/ns1/foo/bar' 
        passing xmltype.createxml(xml) 
        columns id varchar2(10) path '//ns//ns1/id', 
          idboss varchar2(500) path '//ns0//ns1/idboss', 
          etc.... 

        ) nice_xml_table 

Espero que ayude a alguien.

0

esta consulta se ejecuta perfectamente en mi caso

select xmltype(t.axi_content).extract('//Lexis-NexisFlag/text()').getStringVal() from ax_bib_entity t 
0

que puede lograr con consultas a continuación

  1. select extract(xmltype(xml), '//fax/text()').getStringVal() from mytab;

  2. select extractvalue(xmltype(xml), '//fax') from mytab;

0

Puede intentar crear el objeto DBMS_XMLPARSER.parser desde CLOB XML y obtener un objeto DBMS_XMLDOM.DOMDocument a partir de él. Luego use los métodos del paquete DBMS_XMLDOM para obtener el valor de cualquier nodo.

xml_   CLOB := 'X'; 
    p    DBMS_XMLPARSER.parser; 
    doc_   DBMS_XMLDOM.DOMDocument; 

     -- Convert the CLOB into a XML-document 
     P := DBMS_XMLPARSER.newparser(); 
     -- Parse the clob and get the XML-document 
     DBMS_XMLPARSER.parseclob(p, xml_); 
     doc_ := DBMS_XMLPARSER.getDocument(p); 

continuación, utilice los métodos siguientes para extraer valor de nodo

DBMS_XMLDOM.getElementsByTagName (doc_, 'NombreNodo'); DBMS_XMLDOM.GetNodeValue (node_obj_);

Más información sobre los métodos DBMS_XMLDOM here.

0

En caso de:

<?xml version="1.0" encoding="iso-8859-1"?> 
<info xmlns="http://namespaces.default" xmlns:ns2="http://namespaces.ns2" > 
    <id> 954 </id> 
    <idboss> 954 </idboss> 
    <name> Fausto </name> 
    <sorname> Anonimo </sorname> 
    <phone> 040000000 </phone> 
    <fax> 040000001 </fax> 
</info> 

Consulta:

Select * 
from xmltable(xmlnamespaces(default 'http://namespaces.default' 
           'http://namespaces.ns2' as "ns", 
         ), 
       '/info' 
       passing xmltype.createxml(xml) 
       columns id varchar2(10) path '/id', 
         idboss varchar2(500) path '/idboss', 
         etc.... 

       ) nice_xml_table 
Cuestiones relacionadas