Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
XMLQuery以插入/删除XML元素_Xml_Oracle_Plsql_Qxmlquery - Fatal编程技术网

XMLQuery以插入/删除XML元素

XMLQuery以插入/删除XML元素,xml,oracle,plsql,qxmlquery,Xml,Oracle,Plsql,Qxmlquery,我试图体验一下Oracle PLSQL中的XML操作。所有示例都是修改存储在表列中的XML,但我正在尝试修改一个XML变量 这是我的密码- declare l_xml XMLTYPE; l_clob CLOB; begin l_xml:=XMLTYPE('<bookstore> <book category="cooking"> <title lang="en">Everyday Italian</title> <author>Gia

我试图体验一下Oracle PLSQL中的XML操作。所有示例都是修改存储在表列中的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;

有人能告诉我我做错了什么吗?如果可能的话,你能举几个例子吗?

我希望这对我使用Oracle Database 12c Enterprise Edition 12.2.0.1.0-64位产品有所帮助,这对我来说没问题:

下面是将在正确位置插入标记“页面”的代码:

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;
查询返回的目标表达式无效。 因为$tmp/bookstore/book部分返回的是book节点集合,而不是单个元素

如何正确执行此操作的示例很少 1$tmp/bookstore/book[@category eq cooking]插入到属性category=cooking的书中 2$tmp/bookstore/book[2]插入到xml中的第二个boook中。 在每本书中插入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)

要从xml中获取clob值,最好使用xmlserialize

您希望看到什么?在book节点下插入一个子节点。谢谢。。。这是一个解决方案。但是我正在考虑使用xmlquery的实现,因为oracle不赞成使用标准oracle函数请解释一下您在这里做了什么-xmlquery'copy$tmp:=$p modify for$book in$tmp/bookstore/book return将节点260插入$book return$tmp'将l_xml作为p返回内容传递我可以看到两条返回语句Xquery之美:,在这个语句中有两块代码。第一个-内部“用于…”。。返回和第二次外部复制修改返回“”。第一个块中的Return将值传递给外部块,第二个块中的Rturn将值传递给sql。