【问题标题】:Parsing XML in a non-XML column在非 XML 列中解析 XML
【发布时间】:2010-04-12 22:50:16
【问题描述】:

我相当精通 SQLServer,但我不是 DBA,所以我不知道如何处理这个问题。

我有一个 XML 块存储在 ntext 列中。由于它是一个遗留数据库和项目的要求,我无法更改表(还)。这是我需要处理的数据示例:

<XmlSerializableHashtable xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <Entries>
        <Entry>
            <key xsi:type="xsd:string">CurrentYear</key><value xsi:type="xsd:string">2010</value>
        </Entry>
        <Entry>
            <key xsi:type="xsd:string">CurrentMonth</key><value xsi:type="xsd:string">4</value>
        </Entry>
    </Entries>
</XmlSerializableHashtable>

每一行都会有一个这样的块,但显然在 XML 中有不同的键/值。有什么聪明的方法可以将此 XML 解析为名称/值对样式视图吗?或者我应该使用 SQLServer 的 XML 查询功能,即使它不是 XML 列?如果是这样,我将如何从该列中查询特定值?

(注意:如果有帮助,可以在表的末尾添加一个计算的 XML 列)。

感谢您的帮助!

【问题讨论】:

  • 这一切都需要在数据库上完成还是您正在使用某种程序?
  • 是的,需要在数据库中完成 - 我希望将其中一些值分解出来,以便它们可以在另一个视图中使用。

标签: sql-server xml sql-server-2008 sql-server-2005


【解决方案1】:

如果您可以将该列转换为 XML 类型的列,则可以使用 xpath 查询从中获取数据。 OTOH 我猜想将其转换为 XML 的计算列可能会起作用。 YMMV,但测试它应该不难。

您可以使用cross apply 从 XML 值字段中获取重复组。 cross apply 有效地将列的值插入到表值函数中,并允许您对结果进行联接。 This link 显示了如何执行此操作的示例。

实际上我最近(第一次)有机会这样做,但我手头没有代码示例,而且我不记得它了。您可以使用此技术在 XML 文档中以分层结构自连接多个层。

【讨论】:

  • 太棒了,链接的博客文章成功了。通过使用将 ntext 列转换为 xml 的内部 SELECT,然后将其包装在执行 XML 节点选择的 SELECT 中,我能够创建我想要的确切键/值对类型视图 - 所有这些都无需触摸原始表。
  • 仅供参考,我提到的博文在这里:blog.beyondrelational.com/2007/11/… 并包含一堆关于如何在 SQL 中查询 xml 节点的有用示例。
  • @Byron Whitlock - 是的,这不是一个漂亮的景象。有趣的是,随着工作流系统和 SOA 在业界风靡一时,保险单管理系统的供应商正朝着这个方向发展。鉴于我为保险公司构建数据仓库系统,我预计在可预见的未来会有稳定的工作流;-)
猜你喜欢
  • 2011-12-03
  • 2014-10-26
  • 1970-01-01
  • 1970-01-01
  • 2012-08-11
  • 2010-11-24
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多