SQL Server で複数の列をピボットする方法
問題:
アイテム カテゴリ (パネル、AC、Ref など) と売上などのデータを表す列を含むテーブル。ストックとターゲット。このデータを、カテゴリが行になり、列が各カテゴリ (売上、在庫、目標) のそれぞれのデータを保持するピボット形式に変換したいと考えています。
解決策:
これを実現するには、SQL で複数のピボット ステートメントを利用します。サーバー:
SELECT * FROM ( SELECT Branch, Category, Category+'1' As Category1, Category+'2' As Category2, Sales, Stock, Target FROM TblPivot ) AS P -- For Sales PIVOT ( SUM(Sales) FOR Category IN ([Panel], [AC], [Ref]) ) AS pv1 -- For Stock PIVOT ( SUM(Stock) FOR Category1 IN ([Panel1], [AC1], [Ref1]) ) AS pv2 -- For Target PIVOT ( SUM(Target) FOR Category2 IN ([Panel2], [AC2], [Ref2]) ) AS pv3 GO
説明:
ピボットが完了したら、必要に応じて結果を集計したり、さらなるデータ操作を実行したりできます。
以上がSQL Server で複数の列 (売上、株価、目標) を同時にピボットする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。