Oracle
 sql >> Base de données >  >> RDS >> Oracle

Grouper par mois dans Oracle

L'opérateur de concaténation dans Oracle est || . Pas + :

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

De plus, YEAR est une fonction MySQL. Dans Oracle, vous utiliserez EXTRACT(YEAR FROM ....)

Enfin, connaissez-vous le TO_CHAR fonction ?

Vous devriez donc réécrire toute votre requête comme :

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')