Я новичок в Oracle, и я - возможно тривиальный - проблема в выборе. (Я использую Oracle 10g Express Edition).Oracle 10g: Извлечь данные (выберите) из XML (тип CLOB)
Я БД с поля 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», но у меня такие же проблемы. где я ошибаюсь?
не: ORA-06502: PL/SQL: числовые или значение ошибки ORA-06512: на "SYS.XMLTYPE", line 254 ORA-06512: по строке 1 – mymark
Извините ... да, ваш ответ работает отлично! В предыдущем случае у меня есть xml null ^^! – mymark
В 11g я могу оставить '.getStringVal()' -part вне. Не знаю о 10g, поскольку у меня их нет. – user272735