Aceeași lună, două SUMS-uri diferite

Încerc să obțin diferite sume pentru aceeași lună în același an, doar pentru a obține sume de diferite tipuri. Încercat folosind acest cod:

SELECT a.invoice_type, year( a.date ) AS Year, 
       date_format( a.date, '%M' ) AS `month` , 
       Sum( x.amount * x.price ) AS sum FROM records x 
JOIN paper_invoice a ON x.invoice_id = a.invoice_id 
WHERE year( a.date ) = '2012' 
GROUP BY a.invoice_type, Year( a.date ) , Month( a.date ) LIMIT 0 , 30     

dar dă rezultate în diferite rânduri:

http://www.part.lt/img/1505f0f13172922150febede85ddbf0925.png

Dar am nevoie ca acesta să arate ca:

Year | Month   | SUM_GRYNAIS      | SUM_PAVEDIMU
2012 | January | 7597.14997705445 | 58740.2800849304

si etc.

0

3 răspunsuri

Voi de fapt căutați PIVOT. MySql nu are o funcție PIVOT, dar puteți încă să realizați acest lucru. Iată un exemplu de PIVOT în MySql:

http://www.artfulsoftware.com/infotree/queries.php#78

0
adăugat

Incearca asta:

SELECT Year, Month,
MAX(CASE WHEN invoice_type = 'GRYNAIS' THEN sum END) As Sum_GRYNAIS
MAX(CASE WHEN invoice_type = 'PAVEDIMU' THEN sum END) As SUM_PAVEDIMU
FROM
(
SELECT a.invoice_type, year( a.date ) AS Year, 
date_format( a.date, '%M' ) AS `month` , Sum( x.amount * x.price ) AS sum 
FROM records x JOIN paper_invoice a ON x.invoice_id = a.invoice_id 
WHERE year( a.date ) = '2012' GROUP BY a.invoice_type, Year( a.date ) , 
Month( a.date ) LIMIT 0 , 30     

)
GROUP BY Year, Month
0
adăugat
Mulțumesc, acest lucru a funcționat. Perfect! :)
adăugat autor Martynas Benaitis, sursa

Deoarece fiecare lună are o valoare diferită. Încearcă grupul cu numai anul campaniei.

0
adăugat
MySQL - comunitatea Română
MySQL - comunitatea Română
19 participanți

Comunitatea română a programatorilor MySQL.