如何重命名 Oracle XMLTYPE 节点

How to rename an Oracle XMLTYPE node(如何重命名 Oracle XMLTYPE 节点)
本文介绍了如何重命名 Oracle XMLTYPE 节点的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在 PL/SQL 中有一个 XMLType,我需要重命名一些节点和一些值.例如:

I have an XMLType in PL/SQL and I need to rename some of the nodes and some of the values. For example:

<root>
   <fields>
        <a>foo</a>
        <b>bar</b>
   </fields>
</root>

我想把上面的变成这样:

I want to turn the above into this:

<root>
   <fields>
        <a>foo</a>
        <c>baz</c>
   </fields>
</root>

我知道我可以像这样更新值:

I know I can update the value like this:

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>

But how can I update the node name from <b> to <c> (without affecting the contents of the node)?

推荐答案

一种选择是使用 XMLTRANSFORM 重命名节点.另见例如使用 XSLT 重命名节点.

One option is to use XMLTRANSFORM to rename a node. See also e.g. 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>

这篇关于如何重命名 Oracle XMLTYPE 节点的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

SQL to Generate Periodic Snapshots from Transactions Table(用于从事务表生成定期快照的SQL)
MyBatis support for multiple databases(MyBatis支持多个数据库)
Oracle 12c SQL: Missing column Headers in result(Oracle 12c SQL:结果中缺少列标题)
SQL query to find the number of customers who shopped for 3 consecutive days in month of January 2020(查询2020年1月连续购物3天的客户数量)
How to get top 10 data weekly (This week, Previous week, Last month, 2 months ago, 3 month ago)(如何每周获取前十大数据(本周、前一周、上个月、2个月前、3个月前))
Select the latest record for an Id per day - Oracle pl sql(选择每天ID的最新记录-Oracle pl SQL)