Oracle
 sql >> база данни >  >> RDS >> Oracle

Разбор на XML с неизвестни пространства от имена в Oracle SQL

Знам, че това е доста старо, но днес го забелязах и си спомних болката, която изпитах, опитвайки се да се справя с XML с пространство от имена. Моето решение беше да премахна пространствата от имена с XSLT трансформация и да го обработя като обикновен стар XML. Функцията, която използвах, за да направя това, е:

function remove_namespace( i_xml in xmltype )
  return xmltype
is
  v_xml xmltype default i_xml;
  v_xsl varchar2(32767);
begin
  v_xsl := '<?xml version="1.0" encoding="UTF-8"?>
        <xsl:stylesheet version="1.0"
         xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
        <xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
        <xsl:template match="*">
          <!-- remove element prefix (if any) -->
          <xsl:element name="{local-name()}">
          <!-- process attributes -->
          <xsl:for-each select="@*">
            <!-- remove attribute prefix (if any) -->
            <!-- this if filters out any xmlns="" atts that have no
                 namespace prefix in the xml -->
            <xsl:if test="(local-name() != ''xmlns'')">
              <xsl:attribute name="{local-name()}">
                <xsl:value-of select="."/>
              </xsl:attribute>
            </xsl:if>
          </xsl:for-each>
         <xsl:apply-templates/>
         </xsl:element>
         </xsl:template>
         </xsl:stylesheet>';
  return v_xml.transform(xmltype(v_xsl));
end;



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Как да разрешим грешката ORA-12516?

  2. Как да импортирате Oracle 11g RMAN backupset на нов сървър на база данни?

  3. OleDB Доставчик на данни не може да бъде намерен VBA/Excel

  4. Hibernate запазва остарелите данни с hibernate.jdbc.batch_versioned_data

  5. Групиране на записи час по час или ден по ден и попълване на празнини с нула или нула в mysql