집 >데이터 베이스 >MySQL 튜토리얼 >PostgreSQL에서 여러 중첩 `array_agg()` 호출로 인한 예기치 않은 결과를 방지하는 방법은 무엇입니까?
PostgreSQL 쿼리에서 다중 중첩 집계 방지
단일 쿼리에서 array_agg()를 여러 번 호출하면 다음과 같이 예상치 못한 결과가 발생할 수 있습니다. 예시 제공. 이 문제는 여러 행이 있는 테이블을 결합하여 데카르트 곱을 효과적으로 생성할 때 발생합니다. 이 문제를 해결하려면 다음 전략을 고려하세요.
먼저 집계하고 나중에 조인
조인하기 전에 각 테이블의 데이터를 하위 쿼리에 별도로 집계합니다. 이렇게 하면 고유한 행 집합에 대해 집계할 수 있습니다.
SELECT e.id, e.name, e.age, e.streets, array_agg(wd.day) AS days FROM ( SELECT e.id, e.name, e.age, array_agg(ad.street) AS streets FROM employees e JOIN address ad ON ad.employeeid = e.id GROUP BY e.id ) e JOIN workingdays wd ON wd.employeeid = e.id GROUP BY e.id, e.name, e.age;
상관 하위 쿼리 또는 JOIN LATERAL
상관 하위 쿼리 또는 JOIN LATERAL을 사용하여 각 행의 데이터를 집계합니다. 개별적으로 선택적 필터 허용:
상관 하위 쿼리:
SELECT name, age , (SELECT array_agg(street) FROM address WHERE employeeid = e.id) AS streets , (SELECT array_agg(day) FROM workingdays WHERE employeeid = e.id) AS days FROM employees e WHERE e.namer = 'peter';
JOIN LATERAL:
SELECT e.name, e.age, a.streets, w.days FROM employees e LEFT JOIN LATERAL ( SELECT array_agg(street) AS streets FROM address WHERE employeeid = e.id GROUP BY 1 ) a ON true LEFT JOIN LATERAL ( SELECT array_agg(day) AS days FROM workingdays WHERE employeeid = e.id GROUP BY 1 ) w ON true WHERE e.name = 'peter';
이러한 방법은 불필요한 행 중복을 방지하고 원하는 배열 집계 결과를 제공합니다.
위 내용은 PostgreSQL에서 여러 중첩 `array_agg()` 호출로 인한 예기치 않은 결과를 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!