How to Pivot Multiple Columns in SQL Server
Problem:
Suppose you have a table with columns representing item categories (e.g., Panel, AC, Ref) and data such as sales, stock, and target. You want to transform this data into a pivoted format where the categories become rows and the columns hold the respective data for each category (sales, stock, target).
Solution:
To achieve this, you can utilize multiple pivot statements in SQL Server:
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
Explanation:
Once the pivoting is complete, you can aggregate the results or perform further data manipulations as needed.
The above is the detailed content of How to Pivot Multiple Columns (Sales, Stock, Target) Simultaneously in SQL Server?. For more information, please follow other related articles on the PHP Chinese website!