在不了解架构的情况下解析XML

时间:2016-03-03 19:57:07

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

使用SQL Server 2008我想将以下XML转换为下面的表结构。 XML由第三方提供,不能更改,除了recordid之外,每个表都有一个未知的元素列表。

DECLARE @xml XML = '
<NewDataSet>
    <Table1>
        <recordid>1</recordid>
        <Q2_1>aaaa</Q2_1>
        <Q2_2>bbbb</Q2_2>
    </Table1>
    <Table1>
        <recordid>2</recordid>
        <R2_1>eeee</R2_1>
        <R2_2>ffff</R2_2>
    </Table1>
    <Table1>
        <recordid>3</recordid>
        <R2_1>iiii</R2_1>
        <Q2_2>jjjj</Q2_2>
    </Table1>
</NewDataSet>';

样本表

recordid                ElementName                 Value
----------------------------------------------------------
1                       Q2_1                        aaaa
1                       Q2_2                        bbbb
2                       R2_1                        eeee
2                       R2_2                        ffff
3                       R2_1                        iiii
3                       Q2_2                        jjjj

1 个答案:

答案 0 :(得分:2)

SELECT 
    e.e.value('../recordid[1]', 'INT') As [recordid]
    ,e.e.value('fn:local-name(.)', 'NVARCHAR(100)') As [ElementName]
    ,e.e.value('.', 'NVARCHAR(100)') As [Value]
FROM @xml.nodes('/*/*/*') e(e)
WHERE
    e.e.value('fn:local-name(.)', 'NVARCHAR(100)') != 'recordid'