Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Jak zmienić nazwę węzła Oracle XMLTYPE?

Jedną z opcji jest użycie XMLTRANSFORM zmienić nazwę węzła. Zobacz także m.in. Zmień nazwy węzłów za pomocą 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;

Wyjście:

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


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Dapper - wywołaj Oracle schema.package.function

  2. Jak mogę przekazać parametr do skryptu t-sql?

  3. Łączenie z Oracle DB przez C

  4. dołącz do wyszukiwania i groupby

  5. Oracle:skopiuj wiersz podczas aktualizacji jednego pola