sql >> Database >  >> RDS >> Oracle

De naam van een Oracle XMLTYPE-knooppunt wijzigen

Een optie is om XMLTRANSFORM te gebruiken om een ​​knoop te hernoemen. Zie ook bijv. Knooppunten hernoemen met 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;

Uitgang:

XMLTRANSFORM(X.VAL,S.VAL)
--------------------------------------------------------------------------------
<root>
  <fields>
    <a>foo</a>
    <c>bar</c>
  </fields>
</root>


  1. slechte record MAC SSL-fout tussen Java en PortgreSQL

  2. duplicaten verwijderen

  3. MySql-tabel in JSON-indeling

  4. Hoe localdb afzonderlijk te installeren?