How to rename an Oracle XMLTYPE node(如何重命名 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 节点的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何重命名 Oracle XMLTYPE 节点
- 远程 mySQL 连接抛出“无法使用旧的不安全身份验证连接到 MySQL 4.1+"来自 XAMPP 的错误 2022-01-01
- 在SQL中,如何为每个组选择前2行 2021-01-01
- 更改自动增量起始编号? 2021-01-01
- 以一个值为轴心,但将一行上的数据按另一行分组? 2022-01-01
- 如何使用 pip 安装 Python MySQLdb 模块? 2021-01-01
- 导入具有可变标题的 Excel 文件 2021-01-01
- 如何将 Byte[] 插入 SQL Server VARBINARY 列 2021-01-01
- 使用 Oracle PL/SQL developer 生成测试数据 2021-01-01
- SQL 临时表问题 2022-01-01
- 如何将 SonarQube 6.7 从 MySQL 迁移到 postgresql 2022-01-01
