Ответ 1
Попробуйте это вместо:
select xmltype(t.xml).extract('//fax/text()').getStringVal() from mytab t
Я новичок в 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>
Я пытаюсь сделать "простой" выбор, чтобы получить, например, значение тега "fax". Но у меня проблемы, и я не могу понять свою ошибку. Например:
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", но у меня такие же проблемы. где я ошибаюсь, чтобы сделать это?
Попробуйте это вместо:
select xmltype(t.xml).extract('//fax/text()').getStringVal() from mytab t
Попробуйте использовать 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
Надеюсь, это поможет кому-то.
этот запрос отлично работает в моем случае
select xmltype(t.axi_content).extract('//Lexis-NexisFlag/text()').getStringVal() from ax_bib_entity t
Вы можете выполнить следующие запросы
select extract(xmltype(xml), '//fax/text()').getStringVal() from mytab;
select extractvalue(xmltype(xml), '//fax') from mytab;
Вы можете попробовать создать объект DBMS_XMLPARSER.parser из CLOB XML и получить от него объект DBMS_XMLDOM.DOMDocument. Затем используйте методы пакета DBMS_XMLDOM, чтобы получить значение любого node.
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);
Затем используйте приведенные ниже методы для извлечения значения node
DBMS_XMLDOM.getElementsByTagName(doc_, 'NodeName'); DBMS_XMLDOM.GetNodeValue(node_obj _);
Подробнее о методах DBMS_XMLDOM здесь.
В случае:
<?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