sql >> Database teknologi >  >> RDS >> Sqlserver

I SQL Server, hvordan man pivoterer for flere kolonner

Du skal ændre navnet på kolonnerne til næste pivotudsagn.

Synes godt om

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

Du er klar til at gå nu...

Du kan bruge aggregat af pv3 til at summere og gruppere efter den kolonne, du har brug for.



  1. Matchende algoritme i SQL

  2. Gendannelse af en mySQL-instans fra en anden brugerkonto (macOS)

  3. oci_connect forbindelse mislykkedes

  4. Sådan fungerer MATCH()-funktionen i MySQL