Chodzi o to, aby najpierw wygenerować sumę dla każdego typu transakcji, Debit
i Credit
. Po tym dołącz do Bankdetails
aby obliczyć bieżące saldo.
;with cte as(
select
AccNo,
Credit = sum(case when TranType = 'Credit' then Amount else 0 end),
Debit = sum(case when TranType = 'Debit' then Amount else 0 end)
from Trandetails
group by
AccNo
)
select
bd.AccName,
bd.AccNo,
CurrBal = bd.opBal - c.Debit + c.Credit
from BankDetails bd
inner join cte c
on c.Accno = bd.Accno