質問

XML列のあるテーブルを使用したピボットの例はありますか?具体的には、xml列の一部の要素をピボットテーブルの列に変換しますか?私はそれを構築しようとしていますが、構文は私を殺しています。 C#のxmlと比較して、SQLのxmlの操作は非常に困難です。これは不可能だと思いますが、確認しても害はありません:)

役に立ちましたか?

解決

これは、xmlに保存された製品の詳細を持つストアを持つ簡単な例です。ピボットは下部にあり、店舗とカテゴリAおよびBごとの価格の合計が表示されます。

declare @test Table
(

    StoreID int,
    ProdXml xml
)

insert into @test
select 1, '<product cat="A" name="foo" price="10" />' union
select 2, '<product cat="A" name="bar" price="12" />' union
select 1, '<product cat="B" name="blah" price="35" />' union    
select 2, '<product cat="B" name="bap" price="67" />' union
select 1, '<product cat="C" name="bip" price="18" />' union
select 2, '<product cat="A" name="bing" price="88" />' union
select 1, '<product cat="B" name="bang" price="34" />' union    
select 2, '<product cat="B" name="boom" price="65" />' 

--Pivot showing sum of price by Cat
select  StoreID, A, B
from
(   
    select  StoreID,
        ProdXml.value('/product[1]/@cat[1]','varchar(20)') as [ProdCat],
        ProdXml.value('/product[1]/@price[1]','int') as [ProdPrice]
    from  
        @test
) up
PIVOT (SUM([ProdPrice]) FOR [ProdCat] IN ( A, B)) as pvt
ORDER BY StoreID
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top