Oracle
 sql >> Datenbank >  >> RDS >> Oracle

LISTAGG-Alternative in Oracle 10g

Versuchen Sie es mit XMLAGG so:

select
    p.PeopleID,
    rtrim(xmlagg(xmlelement(e, s.SiteName, ',')).extract('//text()').getclobval(), ',')
from people p
join site s on p.SiteID = s.SiteID
group by p.PeopleID;

Wenn Sie die Verkettung in einer bestimmten Reihenfolge benötigen, sagen Sie aufsteigende Reihenfolge der SiteId, und fügen Sie dann ein order by hinzu -Klausel in xmlagg:

select
    p.PeopleID,
    rtrim(xmlagg(xmlelement(e, s.SiteName, ',')
                   order by s.SiteId).extract('//text()').getclobval(), ',')
from people p
join site s on p.SiteID = s.SiteID
group by p.PeopleID;

BEARBEITEN:

Wenn Sie das Ergebnis für alle Personen anzeigen möchten, die Standort 100 zugeordnet sind:

select p.PeopleID,
    rtrim(xmlagg(
                xmlelement(e, s.SiteName, ',') order by s.SiteId
            ).extract('//text()').getclobval(), ',')
from people p
join site s on p.SiteID = s.SiteID
join (
    select distinct PeopleID
    from people
    where siteID = 1
    ) p2 on p.PeopleID = p2.PeopleID
group by p.PeopleID;