gpt4 book ai didi

对三个表进行 SQL JOIN、GROUP BY 以获得总计

转载 作者:行者123 更新时间:2023-12-02 02:26:07 25 4
gpt4 key购买 nike

我继承了以下数据库设计。表格是:

customers
---------
customerid
customernumber

invoices
--------
invoiceid
amount

invoicepayments
---------------
invoicepaymentid
invoiceid
paymentid

payments
--------
paymentid
customerid
amount

我的查询需要返回给定客户编号的发票 ID、发票金额(在发票表中)和应付金额(发票金额减去已向发票支付的所有付款)。一个客户可能有多张发票。

当对一张发票进行多次付款时,以下查询会给出重复的记录:

SELECT i.invoiceid, i.amount, i.amount - p.amount AS amountdue
FROM invoices i
LEFT JOIN invoicepayments ip ON i.invoiceid = ip.invoiceid
LEFT JOIN payments p ON ip.paymentid = p.paymentid
LEFT JOIN customers c ON p.customerid = c.customerid
WHERE c.customernumber = '100'

我该如何解决这个问题?

最佳答案

我不确定是否找到您,但这可能就是您正在寻找的:

SELECT i.invoiceid, sum(case when i.amount is not null then i.amount else 0 end), sum(case when i.amount is not null then i.amount else 0 end) - sum(case when p.amount is not null then p.amount else 0 end) AS amountdue
FROM invoices i
LEFT JOIN invoicepayments ip ON i.invoiceid = ip.invoiceid
LEFT JOIN payments p ON ip.paymentid = p.paymentid
LEFT JOIN customers c ON p.customerid = c.customerid
WHERE c.customernumber = '100'
GROUP BY i.invoiceid

如果每张发票有多个付款行,这将为您提供金额

关于对三个表进行 SQL JOIN、GROUP BY 以获得总计,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1242121/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com