Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Gruppieren Sie, indem Sie nicht mit 2 Feldern Summe arbeiten

Das Problem ist, dass store mit der ID 1 hat zwei entsprechende Datensätze in store_sub Tabelle, was bedeutet, dass qty Das Feld wird für Geschäft 1 zweimal angezeigt. Sie müssen die beiden Tabellen separat in Unterabfragen summieren und die summierten Versionen zusammenfügen:

select t1.department, t1.sqty, t2.ssubqty
from
  (select department, sum(qty) as sqty from store group by department) t1
left join
  (select s2.department, s1.sum(sub_qty) as ssubqty
   from store_sub s1
   inner join store s2 on s1.parent_id=s2.id
   group by s2.department) t2 on t1.department=t2.department