sql >> Databasteknik >  >> RDS >> Oracle

Hur jag tar bort dubbletter från listagg

Välj först DISTINCT-värden du behöver och använd sedan LISTAGG på dem. Här är ett exempel baserat på Scotts schema.

SQL> -- Duplicate jobs within the department
SQL> select deptno, listagg(job, ', ') within group (order by job) jobs
  2  from emp
  3  group by deptno;

    DEPTNO JOBS
---------- ------------------------------------------------------------
        10 CLERK, MANAGER, PRESIDENT
        20 ANALYST, ANALYST, CLERK, CLERK, MANAGER
        30 CLERK, MANAGER, SALESMAN, SALESMAN, SALESMAN, SALESMAN

SQL>
SQL> -- This won't work - DISTINCT can't be used in LISTAGG
SQL> select deptno, listagg(distinct job, ', ') within group (order by job) jobs
  2  from emp
  3  group by deptno;
select deptno, listagg(distinct job, ', ') within group (order by job) jobs
               *
ERROR at line 1:
ORA-30482: DISTINCT option not allowed for this function


SQL>
SQL> -- So - select distinct jobs first, then apply LISTAGG to it
SQL> select x.deptno, listagg(x.job, ', ') within group (order by x.job) jobs
  2  from (select distinct deptno, job
  3        from emp) x
  4  group by x.deptno;

    DEPTNO JOBS
---------- ------------------------------------------------------------
        10 CLERK, MANAGER, PRESIDENT
        20 ANALYST, CLERK, MANAGER
        30 CLERK, MANAGER, SALESMAN

SQL>


  1. Välj det största värdet för de senaste 7 dagarna

  2. MySQL visar resultat i alfabetisk ordning men visar ett visst objekt före den alfabetiskt sorterade listan

  3. Använder SQLAlchemy ORM för en icke-primär nyckel, unikt, auto-inkrementerande ID

  4. Hur man gör dynamiska postgres-förberedda uttalanden i PHP