我在使用 Oracle SQL 和 XML 时遇到问题。
我将从外部系统获得大量格式良好的 XML 数据,用于解析、解释和填充一些表。我使用 XMLTable 编写了一个解决方案,该解决方案在表上的一个视图中进行了布局,其中包含有问题的 xml clob 列以及一些审计信息和内容(我想保持这种方式)。
命名空间让我做噩梦。显然我不能把它们放在 xmlnamespaces 子句中,因为我永远不知道它们会是什么。荒谬!相同类型的交付项目在不同时间点可能具有不同的命名空间。没有有限的清单。甚至默认的 xmlns 也不是恒定的。
到目前为止,我提出的最佳工作解决方案是一组 regexp_replace(准确地说是 3 个),在解析之前擦除所有命名空间。但性能是一个巨大的问题。
当然,我缺少一些聪明的东西吗?