Oracle 10g: извлечение данных (выбор) из XML (тип CLOB) - PullRequest
12 голосов
/ 03 февраля 2011

Я новичок в Oracle, и у меня есть - может быть, тривиальная - проблема в выборе. (Я использую Oracle 10g Express Edition).

У меня есть БД с полем CLOB: mytab.xml Этот столбец имеет XML-код, подобный следующему:

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

Я пытаюсь сделать «простой» выбор, чтобы получить, например, значение тега «факс». Но у меня есть небольшая проблема, и я не могу понять свою ошибку. Например:

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

Я пробовал также с 'extractvalue', но у меня те же проблемы. где я ошибаюсь, чтобы сделать это?

Ответы [ 6 ]

28 голосов
/ 03 февраля 2011

Попробуйте вместо этого:

select xmltype(t.xml).extract('//fax/text()').getStringVal() from mytab t
3 голосов
/ 21 февраля 2012

Попробуйте использовать xmltype.createxml(xml).

Как в,

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

У меня это сработало.

Если вы хотите улучшить или манипулировать еще больше.

Попробуйте что-то вроде этого.

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

Надеюсь, это кому-нибудь поможет.

0 голосов
/ 08 марта 2017

В случае:

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

Запрос:

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
0 голосов
/ 16 июня 2016

Вы можете попробовать создать объект DBMS_XMLPARSER.parser из CLOB XML и получить из него объект DBMS_XMLDOM.DOMDocument.Затем используйте методы пакета DBMS_XMLDOM, чтобы получить значение любого узла.

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

Затем используйте методы ниже для извлечения значения узла

DBMS_XMLDOM.getElementsByTagName (doc_, 'NodeName');DBMS_XMLDOM.GetNodeValue (node_obj _);

Подробнее о методах DBMS_XMLDOM здесь .

0 голосов
/ 11 апреля 2014

Вы можете достичь с помощью нижеуказанных запросов

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

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

0 голосов
/ 29 мая 2013

этот запрос отлично работает в моем случае

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