【发布时间】:2011-06-29 00:44:49
【问题描述】:
我正在执行以下请求,但收到“ORA-00979: not a GROUP BY expression”错误。
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
我知道除了分组函数(如 MAX 或 SUM)之外,我必须将 SELECT 的所有列都放在 GROUP BY 语句中,所以我正在尝试以下查询,但我得到了相同的错误消息:
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
如何在不改变查询的整体含义的情况下解决这个问题?
非常感谢, 马丁
【问题讨论】:
标签: sql oracle oracle11g ora-00979