I am getting ORA-00979 with the following query:
SELECT cr.review_sk, cr.cs_sk, cr.full_name,
tolist(to_char(cf.fact_date, 'mm/dd/yyyy')) "appt",
cs.cs_id, cr.tracking_number
from review cr, cs, fact cf
where cr.cs_sk = cs.cs_sk
and UPPER(cs.cs_id) like '%' || UPPER(i_cs_id) || '%'
and row_delete_date_time is null
and cr.review_sk = cf.review_wk (+)
and cr.fact_type_code (+) = 183050
GROUP BY cr.review_sk, cr.cs_sk, cf.fact_date, cr.tracking_number
ORDER BY cs.cs_id, cr.full_name;
I couldn't find any examples that had both GROUP BY and ORDER BY clauses in the same query. I tried removing each field from the group by one at a time, but am still getting the same error.
You should do the following:
Same error also come when UPPER or LOWER keyword not used in both place in select expression and group by expression .
Wrong :-
Right :-
Include in the
GROUP BY
clause allSELECT
expressions that are not group function arguments.If you do groping by virtue of including
GROUP BY
clause, any expression inSELECT
, which is not group function (or aggregate function or aggregated column) such asCOUNT
,AVG
,MIN
,MAX
,SUM
and so on (List of Aggregate functions) should be present inGROUP BY
clause.Example (correct way) (here
employee_id
is not group function (non-aggregated column), so it must appear inGROUP BY
. By contrast, sum(salary) is a group function (aggregated column), so it is not required to appear in theGROUP BY
clause.Example (wrong way) (here
employee_id
is not group function and it does not appear inGROUP BY
clause, which will lead to the ORA-00979 Error .To correct you need to do one of the following :
SELECT
clause in theGROUP BY
clauseSELECT
clause.The group by is used to aggregate some data, depending on the aggregate function, and other than that you need to put column or columns to which you need the grouping.
for example:
This will result in the departments maximum salary.
Now if we omit the
d.deptno
from group by clause it will give the same error.Too bad Oracle has limitations like these. Sure, the result for a column not in the GROUP BY would be random, but sometimes you want that. Silly Oracle, you can do this in MySQL/MSSQL.
BUT there is a work around for Oracle:
While the following line does not work
You can trick Oracle with some 0's like the following, to keep your column in scope, but not group by it (assuming these are numbers, otherwise use CONCAT)