如何重命名Oracle XMLTYPE节点
发布时间:2021-01-14 03:15:26 所属栏目:站长百科 来源:网络整理
导读:我在PL / SQL中有一个 XMLType,我必要重定名一些节点和一些值.譬喻: root fields afoo/a bbar/b /fields/root 我想把上面的内容酿成这样: root fields afoo/a cbaz/c /fields/root 我知道我可以像这样更新值: SELECT UpdateXML(my_xml,'/root/fields/b/te
|
我在PL / SQL中有一个 XMLType,我必要重定名一些节点和一些值.譬喻: <root>
<fields>
<a>foo</a>
<b>bar</b>
</fields>
</root>
我想把上面的内容酿成这样: <root>
<fields>
<a>foo</a>
<c>baz</c>
</fields>
</root>
我知道我可以像这样更新值: SELECT UpdateXML(my_xml,'/root/fields/b/text()','baz') INTO my_xml_updated FROM DUAL; 功效是: <root>
<fields>
<a>foo</a>
<b>baz</b>
</fields>
</root>
可是怎样从< b>更新节点名称?到< c> (不影响节点的内容)? 办理要领一种选择是行使 XMLTRANSFORM重定名节点.另见譬喻 Rename nodes with XSLT.with
xmldata as (select xmltype('<root>
<fields>
<a>foo</a>
<b>bar</b>
</fields>
</root>') val from dual),stylesheet as (select '<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<!-- Identity transformation -->
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<!-- Identity transformation overridden for element b -->
<xsl:template match="b">
<xsl:element name="c">
<xsl:apply-templates select="node()|@*"/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>' val from dual)
select xmltransform(x.val,s.val) from xmldata x,stylesheet s;
输出: XMLTRANSFORM(X.VAL,S.VAL)
--------------------------------------------------------------------------------
<root>
<fields>
<a>foo</a>
<c>bar</c>
</fields>
</root>
(编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |

