1 Вопрос: Проблема накопления MySQL

вопрос создан в Thu, Mar 28, 2019 12:00 AM

В моем клиенте установлено программное обеспечение Dot Net, и я перевожу его на PHP. Я делаю отчет после этого

 screenshot

Следующий запрос точно работает, но проблема сводится к сведениям об общем филиале, общем количестве единиц, общем количестве судов, общей площади, общей зоне и общей сумме

select sh.NAME ShipName,sh.AREA_ID, pu.NAME PostingName, b.BRANCH_NAME Branch, r.RANK_NAME Rank, p.Name Part, count(SAILORID)Borne,

(SELECT SUM(us.SanctionNo)sanction FROM unitwisesanction us WHERE us.RankID = s.RANKID AND us.PostingUnitID = s.POSTINGUNITID
AND us.PartIIID = s.FIRSTPARTID GROUP BY us.PostingUnitID,us.RankID,us.PartIIID) sanction,

(select count(t.TransferID)TotalOut from transfer t left join sailor ts on t.SailorID = ts.SAILORID where ts.RANKID = s.RANKID
and ts.FIRSTPARTID = s.FIRSTPARTID and t.PostingUnitID = s.POSTINGUNITID )TotalIn,

(select count(t.TransferID)TotalOut from transfer t left join sailor ts on t.SailorID = ts.SAILORID where ts.RANKID = s.RANKID
and ts.FIRSTPARTID = s.FIRSTPARTID and ts.POSTINGUNITID = s.POSTINGUNITID )TotalOut

from sailor s
left join bn_branch b on s.BRANCHID = b.BRANCH_ID
left join bn_rank r on s.RANKID = r.RANK_ID
left join partii p on s.FIRSTPARTID = p.PartIIID
left join bn_daogroup a on b.DAO_GROUPID = a.GROUP_ID
left join bn_ship_establishment sh on s.SHIPESTABLISHMENTID = sh.SHIP_ESTABLISHMENTID
left join bn_posting_unit pu on s.POSTINGUNITID = pu.POSTING_UNITID
where SAILORSTATUS = 1  AND s.ZONEID IN (1) AND s.AREAID IN (5) AND s.SHIPESTABLISHMENTID IN (53,125)  AND a.GROUP_ID IN (1,2,3,4,5,7)
group by s.POSTINGUNITID, RANKID, FIRSTPARTID

Кто-нибудь может мне помочь? Как создать дополнительную строку для всего итога

    
0
  1. Это не то, как вы должны использовать GROUP BY в SQL .. Также см. Почему я должен предоставить MCVE для того, что мне кажется очень простым SQL-запросом? для предоставления примера данных и ожидаемых результатов.
    2019-03-28 11: 42: 09Z
1 ответ                              1                         

Я решил эту проблему с помощью следующего запроса

SELECT coalesce(ShipName, "Ship Total")ShipName, AREA_ID, coalesce(PostingName,"Unit Total")PostingName, coalesce(Branch, "Branch Total")Branch, Rank, Part,
      SUM(Borne) Borne, SUM(sanction) sanction, SUM(TotalIn) TotalIn, SUM(TotalOut) TotalOut
from(
  select s.POSTINGUNITID, RANKID, FIRSTPARTID, sh.NAME ShipName,sh.AREA_ID, pu.NAME PostingName, b.BRANCH_NAME Branch, r.RANK_NAME Rank, p.Name Part, count(SAILORID)Borne,

  (SELECT SUM(us.SanctionNo)sanction FROM unitwisesanction us WHERE us.RankID = s.RANKID AND us.PostingUnitID = s.POSTINGUNITID
  AND us.PartIIID = s.FIRSTPARTID GROUP BY us.PostingUnitID,us.RankID,us.PartIIID) sanction,

  (select count(t.TransferID)TotalOut from transfer t left join sailor ts on t.SailorID = ts.SAILORID where ts.RANKID = s.RANKID
  and ts.FIRSTPARTID = s.FIRSTPARTID and t.PostingUnitID = s.POSTINGUNITID )TotalIn,

  (select count(t.TransferID)TotalOut from transfer t left join sailor ts on t.SailorID = ts.SAILORID where ts.RANKID = s.RANKID
  and ts.FIRSTPARTID = s.FIRSTPARTID and ts.POSTINGUNITID = s.POSTINGUNITID )TotalOut

  from sailor s
  left join bn_branch b on s.BRANCHID = b.BRANCH_ID
  left join bn_rank r on s.RANKID = r.RANK_ID
  left join partii p on s.FIRSTPARTID = p.PartIIID
  left join bn_daogroup a on b.DAO_GROUPID = a.GROUP_ID
  left join bn_ship_establishment sh on s.SHIPESTABLISHMENTID = sh.SHIP_ESTABLISHMENTID
  left join bn_posting_unit pu on s.POSTINGUNITID = pu.POSTING_UNITID
  where SAILORSTATUS = 1  AND s.ZONEID IN (1) AND s.AREAID IN (5) AND s.SHIPESTABLISHMENTID IN (53,125)  AND a.GROUP_ID IN (1,2,3,4,5,7)
  group by s.POSTINGUNITID, RANKID, FIRSTPARTID
) a
GROUP BY ShipName, PostingName, Branch WITH ROLLUP;
    
0
2019-03-28 13: 28: 06Z
источник размещен Вот