嗨,这是我的情况,我有那些桌子
Customer {id,name}
Charges {id,amount,customer_id}
Taxes {id,amount,charge_id}
Run Code Online (Sandbox Code Playgroud)
所以我想总结费用和税费,然后按客户 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;
Run Code Online (Sandbox Code Playgroud)
因此,如果我对客户收取 1 笔费用,而不是在我使用 SUM 功能时收取 2 笔税费,则它会计算两次费用金额,例如,如果显示 10 美元,则显示 20 美元
我知道如何通过子查询来解决这个问题,但我想知道是否有任何选项可以在没有子查询的情况下获得正确的值,比如我上面使用的查询,我可以在那里修改以解决这个问题。
谢谢 !
没有子查询的更新答案
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 …Run Code Online (Sandbox Code Playgroud)