Ý tưởng là đầu tiên tạo tổng cho mỗi loại giao dịch, Debit
và Credit
. Cùng với đó, hãy kết hợp nó với Bankdetails
để tính toán số dư hiện tại.
;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