PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

PostgreSQL 9.1:come concatenare le righe nell'array senza duplicati, UNISCITI a un'altra tabella

Invece di usare le funzioni della finestra e il patitioning, usa un GROUP BY a livello di query e aggrega con una clausola DISTINCT:

SELECT         
  rnp.grp_id,
  array_to_string(array_agg(distinct rnp.cabinets),',') AS cabinets,
  array_to_string(array_agg(distinct ips.address),',')  AS addresses
FROM rnp JOIN ips ON rnp.grp_id=ips.grp_id GROUP BY rnp.grp_id, ips.grp_id;

Risultato:

 grp_id |        cabinets         | addresses 
--------+-------------------------+-----------
     11 | cabs1,cabs2,cabs3,cabs4 | CA,NY
     22 | c1,c2                   | DC,LA
(2 rows)

La chiave qui è che invece di usare le funzioni della finestra e il patizionamento, usi un GROUP BY a livello di query e aggrega con un DISTINCT clausola.

Funzionerebbe anche con l'approccio della funzione finestra, tranne per il fatto che PostgreSQL (almeno 9.1) non supporta DISTINCT nelle funzioni della finestra:

regress=# SELECT DISTINCT
  rnp.grp_id,
  array_to_string(array_agg(distinct rnp.cabinets)OVER (PARTITION BY rnp.grp_id), ',') AS cabinets,                    
  array_to_string(array_agg(distinct ips.address) OVER (PARTITION BY ips.grp_id), ',') AS addresses
FROM rnp JOIN ips ON rnp.grp_id=ips.grp_id;
ERROR:  DISTINCT is not implemented for window functions
LINE 3:   array_to_string(array_agg(distinct rnp.cabinets)OVER (PART...