首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ORA-00979:非GROUP BY表达式问题

ORA-00979:非GROUP BY表达式问题
EN

Stack Overflow用户
提问于 2011-02-17 19:16:58
回答 2查看 10.4K关注 0票数 2

我正在执行以下请求,并收到"ORA-00979: not a GROUP BY expression“错误。

代码语言:javascript
复制
select distinct 
field1, 
field2, 
field3, 
count(*) as field4, 
field5, 
field6,
case
when smt1>0 then 'Deleted'
when smt2>0 then 'Impacted'
when smt3>0 then 'Unknown'
else 'Clean'
end as field7, 
field8, 
field9, 
field10,
field11, 
field12, 
field13
from (<here a big sub query>) A
group by field1, field2
order by field1, field2

我知道我必须将SELECT的所有列放入GROUP BY语句中,但分组函数除外(如MAX或SUM),因此我尝试执行以下查询,但得到相同的错误消息:

代码语言:javascript
复制
select distinct 
field1, 
field2, 
field3, 
count(*) as field4, 
field5, 
field6,
case
when smt1>0 then 'Deleted'
when smt2>0 then 'Impacted'
when smt3>0 then 'Unknown'
else 'Clean'
end as field7, 
field8, 
field9, 
field10,
field11, 
field12, 
field13
from (<here a big sub query>) A
group by field1, field2, field3, field5, field6, field8, field9, field10, field11, field12, field13
order by field1, field2

我如何才能在不改变查询整体含义的情况下解决这个问题?

非常感谢你,马丁

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-02-17 19:20:29

group by表达式中缺少field7

此外,您不能在同一查询的group by表达式中使用别名。您需要在group by表达式中添加完整的CASE语句以包含field7。

在group by中只提到别名是不可能的,因为SELECT步骤是执行查询的最后一步,当别名还没有定义时,分组发生得更早。

票数 5
EN

Stack Overflow用户

发布于 2011-02-17 19:21:42

您需要添加表达式

代码语言:javascript
复制
case
when smt1>0 then 'Deleted'
when smt2>0 then 'Impacted'
when smt3>0 then 'Unknown'
else 'Clean'
end

添加到group by表达式中。

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

https://stackoverflow.com/questions/5028212

复制
相关文章

相似问题

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