Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

LISTAGG no ORACLE


A LISTAGG função analítica foi introduzida no Oracle 11g Release 2 . Portanto, se você estiver na versão mais antiga, não poderá usá-la.

O erro parece estranho. Na verdade, você deve obter ORA-00904: "DEPTNAME": invalid identifier como o padrão EMP tabela em SCOTT esquema não tem a coluna DEPTNAME. Além disso, você deve obter ORA-00979: not a GROUP BY expression pois você não mencionou o SELECT colunas ed em GROUP BY expressão.

Usando o padrão EMP tabela em SCOTT esquema:
SQL> SELECT deptno,
  2    job,
  3    LISTAGG(ename, ',') WITHIN GROUP (
  4  ORDER BY ename) AS employees
  5  FROM emp
  6  GROUP BY deptno,
  7    job;

    DEPTNO JOB       EMPLOYEES
---------- --------- ------------------------
        10 CLERK     MILLER
        10 MANAGER   CLARK
        10 PRESIDENT KING
        20 CLERK     ADAMS,SMITH
        20 ANALYST   FORD,SCOTT
        20 MANAGER   JONES
        30 CLERK     JAMES
        30 MANAGER   BLAKE
        30 SALESMAN  ALLEN,MARTIN,TURNER,WARD

9 rows selected.

SQL>