質問

以下にテーブルに変換しようとしている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)
役に立ちましたか?

解決

このクエリを試してください

  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);

他のヒント

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フィドルデモ

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top