Der Verkettungsoperator in Oracle ist ||
. Nicht +
:
SQL> select 'a' +' b' from dual;
select 'a' +' b' from dual
*
ERROR at line 1:
ORA-01722: invalid number
SQL> select 'a' || 'b' from dual;
'A
--
ab
Außerdem YEAR
ist eine MySQL-Funktion. In Oracle verwenden Sie EXTRACT(YEAR FROM ....)
Kennen Sie schließlich den TO_CHAR
Funktion?
Sie sollten also Ihre gesamte Abfrage wie folgt umschreiben:
SELECT TO_CHAR(day_date, 'MM-YYYY') AS MY_DATE,
sum(cash_sales) as cash_sales, sum(unit_sales) as unit_sales
FROM NC_SALES_CAT_TL
GROUP BY TO_CHAR(day_date, 'MM-YYYY')