sql >> Databasteknik >  >> RDS >> Sqlserver

SQL-fråga för att visa produktförsäljning

Du kan aggregera data med SUM- och CASE-satser.

Med hjälp av dina tabelldefinitioner (och några mycket minimala sammanställda data), här är ett exempel på hur du kan göra det:

--** Create test tables
DECLARE @SalesLog TABLE ( 
SalesID int IDENTITY(1,1) NOT NULL, 
MemoNo int NULL, 
ProductCode int NULL, 
Quantity int NULL, 
Price int NULL, 
ProductGroup int NULL)

DECLARE @Products TABLE( 
ProductId int IDENTITY(1,1) NOT NULL, 
pName nvarchar(50) COLLATE SQL_Latin1_General_CP1_CI_AS NULL, 
pSize int NULL, 
pPrice int NULL, 
pPackQty int NULL, 
pGroup int NULL, 
pCode int NULL, 
pStock int NULL, 
pYrStock int NULL, 
pClearStock int NULL)

--** Setup test data
INSERT INTO @SalesLog ( MemoNo, ProductCode, Quantity, Price, ProductGroup)
SELECT   0, 1, 500, 0, 1 UNION
SELECT   0, 2, 700, 0, 1 UNION   
SELECT   0, 2, 333, 0, 1 UNION   
SELECT   0, 3, 200, 0, 2 UNION
SELECT   0, 4, 125, 0, 2 ;

INSERT INTO @Products (pName, pSize, pPrice, pPackQty, pGroup, pCode, pStock, pYrStock, pClearStock)
SELECT 'Beer', 350, 1 , 1, 1, 1, 0, 0, 0 UNION
SELECT 'Beer', 650, 1 , 1, 1, 2, 0, 0, 0 UNION
SELECT 'Beer', 1000, 1 , 1, 1, 3, 0, 0, 0 UNION
SELECT 'Wine', 750, 1 , 1, 2, 4, 0, 0, 0 UNION 
SELECT 'Wine', 1000, 1 , 1, 2, 5, 0, 0, 0 ;

--** Example query
SELECT t.pName AS 'Product'
     , MAX(CASE WHEN t.Col = 1 THEN t.pSize END) AS 'Item Size'
     , ISNULL(SUM(CASE WHEN t.Col = 1 THEN t.Quantity END),0) AS 'Quantity'
     , MAX(CASE WHEN t.Col = 2 THEN t.pSize END) AS 'Item Size'
     , ISNULL(SUM(CASE WHEN t.Col = 2 THEN t.Quantity END),0) AS 'Quantity'
     , MAX(CASE WHEN t.Col = 3 THEN t.pSize END) AS 'Item Size'
     , ISNULL(SUM(CASE WHEN t.Col = 3 THEN t.Quantity END),0) AS 'Quantity'
FROM (
SELECT pName
     , pCode
     , pGroup
     , pSize
     , sl.Quantity
     , DENSE_RANK() OVER(PARTITION BY p.pGroup ORDER BY p.pSize) AS Col
  FROM @Products AS p
  LEFT JOIN @SalesLog AS sl
    ON p.pGroup = sl.ProductGroup
   AND p.pCode = sl.ProductCode
     ) AS t
 GROUP BY t.pGroup
     , t.pName
;   

Frågan använder DENSE_RANK-funktionen för att gruppera objekt av en storlek tillsammans och beställa dem i sändningsordning efter storlek och detta används för att räkna ut vilken kolumn data ska skrivas till.

Även om det finns en PIVOT-operator i SQL Server 2005 och senare, är det inte särskilt användbart när du har olika kolumnrubriktyper (artikelstorlek och kvantitet i det här fallet).

Du måste bestämma det maximala antalet produktstorlekar som du vill rapportera om eftersom detta är hårdkodat i frågan. Så om det maximala antalet produktstorlekar är 3 så kodar du frågan enligt ovan. Men om en av dina produkter har 4 olika storlekar, kommer du att lägga till ytterligare ett kolumnpar för artikelstorlek och kvantitet för t.Col =4 och så vidare.

Jag hoppas att detta hjälper.



  1. Bestäm land från IP - IPv6

  2. Analysera en separat PHP-array i Javascript

  3. Hämta flera poster från xml-kolumnen med värde() i SQL Server

  4. Ta bort flera poster med AJAX