首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL错误:ORA-00979:不是GROUP BY表达式

SQL错误:ORA-00979:不是GROUP BY表达式
EN

Stack Overflow用户
提问于 2019-12-19 23:19:30
回答 2查看 52关注 0票数 1

显示订货总数量大于等于100的订货物料的物料编码、供应商名称、总数量。

代码语言:javascript
复制
SELECT QUOT.sname, ORD.Qtyordered,SUM(ORD.QTYORDERED)
from Quotation QUOT
    inner join Orders ORD ON QUOT.QuotationId = ORD.QuotationId
GROUP BY QUOT.sname 
HAVING SUM(ORD.QTYORDERED) >=100 /* No Error */

SELECT QUOT.Itemcode, QUOT.sname, ORD.Qtyordered, SUM(ORD.QTYORDERED)
from Quotation QUOT
    inner join Orders ORD ON QUOT.QuotationId = ORD.QuotationId
GROUP BY QUOT.sname 
HAVING SUM(ORD.QTYORDERED) >=100 /* ERROR not a group by expression */

我是SQL的初学者,有人能帮我写一个查询吗?

EN

回答 2

Stack Overflow用户

发布于 2019-12-19 23:22:28

不要选择ORD.QtyorderedITEM_CODE作为单独的列。它们不适用于sname的聚合查询

代码语言:javascript
复制
SELECT QUOT.sname, SUM(ORD.QTYORDERED)
from Quotation QUOT inner join
     Orders ORD
     ON QUOT.QuotationId = ORD.QuotationId
GROUP BY QUOT.sname 
HAVING SUM(ORD.QTYORDERED) >= 100 ;

如果你想要这些项目,你可能需要LISTAGG()

或者,对于提出的问题,将该项目包括在GROUP BY

代码语言:javascript
复制
SELECT QUOT.Itemcode, QUOT.sname, SUM(ORD.QTYORDERED)
from Quotation QUOT inner join
     Orders ORD
     ON QUOT.QuotationId = ORD.QuotationId
GROUP BY QUOT.Itemcode, QUOT.sname 
HAVING SUM(ORD.QTYORDERED) >= 100 ;

100的限制是订单中的每个项目,而不是项目。

票数 2
EN

Stack Overflow用户

发布于 2019-12-19 23:22:49

看起来您只需要调整查询的GROUP BY来满足您拥有的其他列的需求:

代码语言:javascript
复制
SELECT  QUOT.Itemcode,
        QUOT.sname,
        SUM(ORD.QTYORDERED)
  FROM  Quotation QUOT
    INNER JOIN Orders ORD ON QUOT.QuotationId = ORD.QuotationId
  GROUP BY QUOT.Itemcode, QUOT.sname 
  HAVING SUM(ORD.QTYORDERED) >=100

在使用GROUP BY执行聚合操作时,每个非聚合列都应该包含在GROUP BY语句中。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59412563

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档