首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >解析XML而不知道架构

解析XML而不知道架构
EN

Stack Overflow用户
提问于 2016-03-03 19:57:06
回答 1查看 560关注 0票数 1

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

代码语言:javascript
复制
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>';

样本表

代码语言:javascript
复制
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
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-03-03 20:12:30

代码语言:javascript
复制
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'
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35781794

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档