0

我有一张包含不同发票的发票表。每张发票都有唯一的发票编号和金额值。发票有两种。一种是发票类型,另一种是结算类型。如果创建了发票,表中的条目将是发票类型,金额将为正数。如果用户支付了该发票,则将在表中输入另一个具有相同发票编号但金额为负数的条目,因为用户已支付该金额。

现在我想显示记录是否存在任何两个具有相同发票编号的记录,然后显示计算金额总和的记录(这意味着添加发票金额类型记录和结算类型记录)。而那些具有唯一发票编号(无结算记录)的记录应按原样显示(无金额)。

我猜这个查询会是这样的..,但这不是我想要的!

Select 
    InvoiceNumber, InvoiceTypeCode, 
    Amount = case when COUNT(InvoiceNumber) > 1
                   then SUM(Amount)
                   else Amount
             end
from 
    Invoice
group by 
    InvoiceNumber, Amount, InvoiceTypeCode
4

1 回答 1

5

您不需要区分案例,如果您有一条记录,则总和与值相同。

您不应该对金额和类型代码进行分组,那么具有相同发票编号的两条记录将在不同的组中。

select
  InvoiceNumber, Amount = sum(Amount)
from
  Invoice
group by
  InvoiceNumber
于 2013-07-06T08:05:24.257 回答