在 Oracle SQL 中解析具有未知名称空间的 XML
Posted
技术标签:
【中文标题】在 Oracle SQL 中解析具有未知名称空间的 XML【英文标题】:Parsing XML with unknown namespaces in Oracle SQL 【发布时间】:2012-10-22 20:05:35 【问题描述】:我在使用 Oracle SQL 和 XML 时遇到问题。
我将从外部系统获取大量格式良好的 XML 数据,用于解析、解释和填充一些表。我使用 XMLTable 编写了一个解决方案,该解决方案在表上的一个视图中进行了布局,其中包含有问题的 xml clob 列以及一些审计信息和内容(我想保持这种方式)。
NAMESPACES 让我做噩梦。显然我不能将它们放在 xmlnamespaces 子句中,因为我永远无法知道它们会是什么。荒谬!相同类型的交付项目在不同时间点可能具有不同的命名空间。没有有限的清单。甚至默认的 xmlns 也不是常量。
到目前为止,我提出的最佳工作解决方案是一组 regexp_replace(准确地说是 3 个),在解析之前擦除所有命名空间。但性能是个大问题。
我肯定缺少一些聪明的东西吗?
【问题讨论】:
您有您的代码以便我们更好地为您提供帮助吗? Oracle 强制执行安全性并停止对外部 XML 模式 URL 的任何调用,这意味着所有有效模式都需要使用DBMS_XMLSCHEMA(register schema)
在数据库中注册,很多模式已经在数据库中注册。但是,如果它们不是,那么您必须从所有第三方(发送 XML)获取它们的列表并在 Oracle 中注册它们。
【参考方案1】:
我知道这已经很老了,但我今天发现了它,并记得我在尝试处理命名空间 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;
【讨论】:
以上是关于在 Oracle SQL 中解析具有未知名称空间的 XML的主要内容,如果未能解决你的问题,请参考以下文章