【问题标题】:SQLite Error - misuse of aggregate: sum()SQLite 错误 - 滥用聚合:sum()
【发布时间】:2016-03-05 15:39:05
【问题描述】:

您好,我在以下查询中误用了聚合:sum() 错误。这有什么问题。

> Select storeid, supplierid, ordernumber, inwardnumber, returnid,
> taxinvoiceno, ordervalue, sum(CASHPAID) as 'CASHPAID', balancedue,
> paidamt, paiddate, sum(ADJUSTMENT) as
> ADJUSTMENT,ordervalue+sum(ADJUSTMENT) as total from
> supplierpaymentstabledb where storeid = 10008 and total!=CASHPAID
> group by inwardnumber

【问题讨论】:

    标签: android mysql sql sqlite


    【解决方案1】:

    作为一种良好做法,您应该将所有非聚合列放在group by 子句中。然后,聚合列上的条件应该在 having 子句中,而不是 where 子句中:

    Select storeid, supplierid, ordernumber, inwardnumber, returnid,
           taxinvoiceno, ordervalue, sum(CASHPAID) as CASHPAID, balancedue,
           paidamt, paiddate, sum(ADJUSTMENT) as ADJUSTMENT, 
           ordervalue + sum(ADJUSTMENT) as total
    from supplierpaymentstabledb
    where storeid = 10008 
    group by storeid, supplierid, ordernumber, inwardnumber, returnid,
             taxinvoiceno, ordervalue, balancedue,
             paidamt, paiddate
    having total <> CASHPAID;
    

    【讨论】:

    • 我只想按 inwardnumber 分组。我可以吗?
    • @Seenu69 在选择列表中,您可以有聚合或分组列。我知道的唯一例外是带有“扩展分组依据”的 MySQL。如果您只想对一列进行分组,则另一列必须是聚合。您可以将 min(col) 或 max(col) 用于其他非分组列(当然 sum() 除外)。
    • @Seenu69 。 . .是的,但是您需要弄清楚您想要在其他列中显示什么(如果您需要它们)。
    猜你喜欢
    • 1970-01-01
    • 2018-10-10
    • 2012-03-16
    • 2010-10-13
    • 1970-01-01
    • 2017-12-11
    • 2015-05-19
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多