>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL에서 여러 중첩 `array_agg()` 호출로 인한 예기치 않은 결과를 방지하는 방법은 무엇입니까?

PostgreSQL에서 여러 중첩 `array_agg()` 호출로 인한 예기치 않은 결과를 방지하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-03 01:17:37330검색

How to Avoid Unexpected Results from Multiple Nested `array_agg()` Calls in PostgreSQL?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.