XMLQuery для вставки / удаления элементов XML - PullRequest
1 голос
/ 23 октября 2019

Я пытаюсь почувствовать вкус XML-манипуляции в Oracle PLSQL. Все примеры касаются изменения XML, хранящегося в столбце таблицы, но я пытаюсь изменить переменную XML.

Вот мой код -

declare
l_xml XMLTYPE;
l_clob CLOB;

begin
l_xml:=XMLTYPE('<bookstore>
<book category="cooking">
<title lang="en">Everyday Italian</title>
<author>Giada De Laurentiis</author>
<year>2005</year>
<price>30.00</price>
</book>
<book category="children">
<title lang="en">Harry Potter</title>
<author>J K. Rowling</author>
<year>2005</year>
<price>29.99</price>
</book>
<book category="web">
<title lang="en">XQuery Kick Start</title>
<author>James McGovern</author>
<author>Per Bothner</author>
<author>Kurt Cagle</author>
<author>James Linn</author>
<author>Vaidyanathan Nagarajan</author>
<year>2003</year>
<price>49.99</price>
</book>
<book category="web" cover="paperback">
<title lang="en">Learning XML</title>
<author>Erik T. Ray</author>
<year>2003</year>
<price>39.95</price>
</book>
</bookstore>');

select XMLQuery('copy $tmp := $p modify insert node 
<Pages>260 </Pages>
as last into $tmp/bookstore/book
return $tmp
'
passing l_xml as "p"
returning CONTENT).getCLobVal() into l_clob from dual;
DBMS_OUTPUT.PUT_LINE(l_clob);

end;

Может кто-нибудь, пожалуйста, дайте мне знать, что яделаю неправильно - если возможно, пожалуйста, покажите пару примеров ..

Ответы [ 2 ]

1 голос
/ 24 октября 2019

Ваш запрос возвращает Invalid target expression. Потому что эта часть $tmp/bookstore/book возвращает коллекцию книжного узла, а не один элемент.

Несколько примеров, как сделать это правильно
1) $tmp/bookstore/book[@category eq "cooking"] вставить в книгу, где атрибут category = "cooking"
2) $tmp/bookstore/book[2] вставить во 2-й бук в вашем xml.
3) Вставьте страницы в каждую книгу

XMLQuery('copy $tmp := $p modify 
(for $book in $tmp/bookstore/book return insert node <Pages>260 </Pages> into $book)
return $tmp'
passing l_xml as "p"
returning CONTENT)

Примечание
Для получения значения clob из xml лучше использовать xmlserialize

1 голос
/ 23 октября 2019

Я надеюсь, что это поможет (я использую Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production), и это нормально для меня:

Вот код, который вставит тег «Страницы»в нужном месте:

select INSERTCHILDXML(l_xml,
   '/bookstore/book', 'Pages',
   XMLType('<Pages>260</Pages>')) into l_xml
   from dual;

А вот что внутри начала-конца:

/*from this part it is the same code as you have given us*/
declare
l_xml XMLTYPE;
l_clob CLOB;

begin
l_xml:=XMLTYPE('<bookstore>
<book category="cooking">
<title lang="en">Everyday Italian</title>
<author>Giada De Laurentiis</author>
<year>2005</year>
<price>30.00</price>
</book>
<book category="children">
<title lang="en">Harry Potter</title>
<author>J K. Rowling</author>
<year>2005</year>
<price>29.99</price>
</book>
<book category="web">
<title lang="en">XQuery Kick Start</title>
<author>James McGovern</author>
<author>Per Bothner</author>
<author>Kurt Cagle</author>
<author>James Linn</author>
<author>Vaidyanathan Nagarajan</author>
<year>2003</year>
<price>49.99</price>
</book>
<book category="web" cover="paperback">
<title lang="en">Learning XML</title>
<author>Erik T. Ray</author>
<year>2003</year>
<price>39.95</price>
</book>
</bookstore>');
/*to this part it is the same code as you have given us*/

/*this is just one example how you can add <Pages> tag*/
select INSERTCHILDXML(l_xml,
   '/bookstore/book', 'Pages',
   XMLType('<Pages>260</Pages>')) into l_xml
   from dual;

/*this part is so you can see what you did :)*/
select l_xml.getClobVal() 
into l_clob from dual;

DBMS_OUTPUT.PUT_LINE(l_clob);

end;
...