Oracle
 sql >> Database >  >> RDS >> Oracle

LISTAGG in ORACLE

Il LISTAGG la funzione analitica è stata introdotta in Oracle 11g Release 2 . Quindi, se utilizzi una versione precedente, non potrai utilizzarla.

L'errore sembra strano. Dovresti effettivamente ottenere ORA-00904: "DEPTNAME": invalid identifier come EMP standard tabella in SCOTT lo schema non ha la colonna DEPTNAME. Inoltre, dovresti ottenere ORA-00979: not a GROUP BY expression poiché non hai menzionato SELECT ed nelle colonne GRUPPO PER espressione.

Utilizzando lo standard EMP tabella in SCOTT schema:

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>