Суммирование в sql

У меня есть результат запроса Таблицатаблица результатов, я хотел бы суммировать сумму счета, чтобы он возвращал одну строку с отдельным счетом, балансом, суммой выставленного счета fPreviousReading, fCurrentReading, fПотребление.

результат должен быть

1.account 11074 
2.balance269.49
3.sumbilledamount 520.48
4. fPreviousReading 574 
5 fCurrentReading 612 
6 fConsumption 38

Спасибо

запрос

select 
    Ten.Account,
    ten.DCBalance AS Balance,   
    SUM(T.fInclusiveAmount)AS BilledAmount,  
    MRD.fPreviousReading,    
    MRD.fCurrentReading , 
    MRD.fConsumption ,  
    T.cDescription 
    from _mtblTransactions T 
    left join _mtblProperties P ON P.idProperty = T.iPropertyID
    left join _mtblPropertyPortions PP ON PP.idPropertyPortions = T.iPortionID
    left join _mtblPropertyPortionServices PPS ON PPS.idPropertyPortionServices = T.iPropertyPortionServiceID
    left join _mtblCategories Cat ON Cat.idCategory = PP.iPortionUsageID        
    left join _mtblServices S ON PPS.iPortionServiceID = S.idService        
    left join _mtblServiceGroups SG ON S.iServiceGroupID = SG.idServiceGroup        
    left join _mtblRateTariffs RT ON RT.idRateTariffs = PPS.iServiceRateTariffID        
    left join Client Ten ON T.iCustomerID = Ten.DCLink  
    left join _mtblMeters M ON PPS.iPropertyPortionMeterID = M.idMeter      
    left join _mtblWalkDetails WD ON WD.iWalkMeterID = PPS.iPropertyPortionMeterID     
    left join _mtblWalks W ON WD.iWalkID = W.idWalk    
    left join Client Own ON P.iPropertyOwnerID = Own.DCLink
    left outer join _mtblRegions R on R.idRegions = P.iPropertyRegionID   
    left outer join _mtblSubRegions SR on SR.idSubRegions = P.iPropertySubRegionID   
    left outer join _mtblAreas A on A.idAreas = P.iPropertyAreaID   
    left join _etblPeriod PER ON T.iPeriodID = PER.idPeriod    
    left join _mtblMeterReadingDetails MRD ON T.iMeterID = MRD.iMeterReadingsMeterID and T.iPeriodID = MRD.iBillingPeriodID 
    and MRD.iReadingType=0  

    Where 
    oWN.Account='11074'
    and idPeriod='79'
        GROUP BY Ten.Account,ten.DCBalance,MRD.fPreviousReading,   MRD.fCurrentReading,   MRD.fConsumption,   T.cDescription 

Что вы получаете от всего вышесказанного и чем оно отличается от того, что вы хотите

Eric 10.08.2018 14:43

Не видя, что вы получаете, я не уверен на 100%, что нужно сделать, но мог бы предположить, что для некоторых других столбцов, возможно, потребуются агрегированные функции, примененные к ним. В стороне, почему вы начинаете использовать «левое внешнее соединение», а затем возвращаетесь обратно к просто «левому соединению»?

Cearon O'Flynn 10.08.2018 15:00

Замените WHERE на AND, чтобы получить результат LEFT JOIN. Также подумайте о чтении stackoverflow.com/help/mcve.

jarlh 10.08.2018 15:07

привет всем, что я получаю, так это результат на прикрепленной картинке

Chisanga Mukosa 10.08.2018 15:20

Нажмите на таблицу результатов в первой строке вопроса, она покажет получаемый результат.

Chisanga Mukosa 10.08.2018 15:22
0
5
43
1

Ответы 1

Поскольку я не знаю ваших данных, есть вероятность, что я написал вам код, который вернет несколько двойных строк. Но с этой проблемой легко справиться.

Тем не менее попробуйте:

SELECT t1.Account,
       t1.Balance,
       t1.BilledAmount,
       t1.fPreviousReading,
       t1.fCurrentReading,
       t1.fConsumption,
       t2.cDescription
  FROM (SELECT Ten.Account,
               ten.DCBalance AS Balance,
               SUM (T.fInclusiveAmount) AS BilledAmount,
               SUM (MRD.fPreviousReading) AS fPreviousReading,
               SUM (MRD.fCurrentReading) AS fCurrentReading,
               SUM (MRD.fConsumption) AS fConsumption
          FROM      _mtblTransactions T
            left join _mtblProperties P ON P.idProperty = T.iPropertyID
            left join Client Ten ON T.iCustomerID = Ten.DCLink
            left join Client Own ON P.iPropertyOwnerID = Own.DCLink AND oWN.Account='11074'
            left join _etblPeriod PER ON T.iPeriodID = PER.idPeriod
            left join _mtblMeterReadingDetails MRD ON T.iMeterID = MRD.iMeterReadingsMeterID and T.iPeriodID = MRD.iBillingPeriodID
            and MRD.iReadingType=0
            and idPeriod='79'
                GROUP BY Ten.Account,ten.DCBalance) t1
  JOIN (SELECT T.cDescription,
               Ten.Account,
               ten.DCBalance
          FROM      _mtblTransactions T
            left join Client Ten ON T.iCustomerID = Ten.DCLink) t2 ON t2.Account = t1.Account AND t2.DCBalance = t1.DCBalance

Другие вопросы по теме