1

我有下面的 xml,我正在尝试将其转换为表格。

declare @X xml = 
'<root>
<items>
    <item ItemID="100">
        <obj ObjID="0001" value="val1"/>
        <obj ObjID="0002" value="val2"/>
        <obj ObjID="0003" value="val3"/>
        <obj ObjID="0004" value="val4"/>
    </item>
    <item ItemID="200">
        <obj ObjID="0001" value="val1"/>
        <obj ObjID="0002" value="val2"/>
        <obj ObjID="0003" value="val3"/>
        <obj ObjID="0004" value="val4"/>
    </item>
</items>
</root>'

如何将上述 xml 转换为如下表结构:

ItemID    ObjID
100       0001
100       0002
100       0003
100       0004
200       0001
200       0002
200       0003
200       0004

我已经尝试过下面的语句,但它继续为两个 (ItemID, ObjID) 列提供 NULL 值。

select 
    t.col.value('(/item/@ItemID)[1]', 'nvarchar(16)') as [ItemID],
    t.col.value('(/item/obj/@ObjID)[1]', 'nvarchar(16)') as [ObjID]
from 
@X.nodes('/root/items') as t(col)
4

2 回答 2

3

试试这个查询

  SELECT 
    Tbl.Col.value('../@ItemID', 'nvarchar(16)') as [ItemID],  
    Tbl.Col.value('@ObjID', 'nvarchar(16)') as [ObjID]   
  FROM 
    @x.nodes('root/items/item/obj') Tbl(Col);
于 2013-11-07T04:23:11.530 回答
2
select
    i.col.value('@ItemID', 'nvarchar(16)') as [ItemID],
    o.col.value('@ObjID', 'nvarchar(16)') as [ObjID]     
from @X.nodes('/root/items/item') as i(col)
    outer apply i.col.nodes('obj') as o(col)

sql fiddle demo

于 2013-11-07T12:29:04.467 回答