sql >> Database >  >> RDS >> Oracle

Haal verschillende waarden op met LISTAGG in Oracle 12C

U hebt een extra stap nodig:zoek eerst afzonderlijke waarden en aggregeer ze vervolgens. Bijvoorbeeld:

SQL> with test (id, col) as
  2    (select 1, 'x' from dual union all
  3     select 1, 'x' from dual union all
  4     --
  5     select 2, 'w' from dual union all
  6     select 2, 't' from dual union all
  7     select 2, 'w' from dual union all
  8     --
  9     select 3, 'i' from dual
 10    ),
 11  -- first find distinct values ...
 12  temp as
 13    (select distinct id, col from test)
 14  -- ... then aggregate them
 15  select id,
 16         listagg(col, ';') within group (order by col) result
 17  from temp
 18  group by id;

        ID RESULT
---------- ----------
         1 x
         2 t;w
         3 i

SQL>



  1. MySQL:selecteer zoekopdracht, in stappen van 5 minuten

  2. MySql-query op combinatie van AND en OR

  3. Opgeslagen procedure zorgt ervoor dat Commando's niet synchroon lopen bij de volgende query

  4. Mijn favoriete PostgreSQL-extensies - deel één