嗨,这是我的情况,我有那些桌子
Customer {id,name}
Charges {id,amount,customer_id}
Taxes {id,amount,charge_id}
所以我想计算费用和税费的总和,然后按客户 ID 分组,这是我的查询
SELECT SUM(ch.amount),SUM(t.amount)
FROM Customer c
LEFT JOIN Charges ch ON ch.customer_id = c.id
LEFT JOIN Taxes t ON t.charge_id = ch.id
GROUP BY c.id;
因此,如果我为客户收取 1 笔费用,那么当我使用 SUM 函数时,我会为该费用缴纳 2 笔税费,例如,如果显示 10 美元,则显示 20 美元,则会计算两次费用金额
我知道如何通过子查询来解决这个问题,但我想知道是否有任何选项可以在没有子查询的情况下获得正确的值,例如我上面使用的查询,我可以在那里修改什么来解决这个问题。
Thanks !
没有子查询的更新答案
SELECT
SUM(CASE WHEN @ch_id != ch.id
THEN ch.amount END) AS ch_amount,
SUM(t.amount) AS t_sum,
c.*,
@ch_id := ch.id
FROM
Customer c
LEFT JOIN charges ch ON c.id = ch.reservation_id
LEFT JOIN taxes t ON ch.id = t.charge_id
GROUP BY rs.id;