LATERAL JOIN을 사용하여 배열 인수가 포함된 여러 함수 호출 처리
PostgreSQL에서 배열을 사용하여 집합 반환 함수에 대한 여러 호출 처리 논쟁은 어려울 수 있습니다. 이는 함수가 행 배열에서 작동하고 추가 열이 있는 행 집합을 반환할 때 특히 분명해집니다.
제한 사항 이해
표준 접근 방식에는 전달이 포함됩니다. 배열을 함수에 대한 단일 매개변수로 사용하고 후속 쿼리를 사용하여 관련 데이터를 추출합니다. 그러나 이 접근 방식은 배열의 각 행에 대해 한 번만 호출하여 함수를 여러 번 호출하는 경우가 많습니다.
LATERAL JOIN 솔루션
이 제한 사항을 해결하려면, PostgreSQL 9.3 이상에서는 LATERAL JOIN 연산자가 도입되었습니다. 이 연산자를 사용하면 행별로 평가된 조건에 따라 테이블을 조인할 수 있으므로 여러 함수 호출이 필요하지 않습니다.
다음 쿼리는 LATERAL JOIN을 사용하여 함수 집합을 조인하는 방법을 보여줍니다.
SELECT sub.dataid, f.* FROM ( SELECT dataid, array_agg(data) AS arr FROM dataset WHERE dataid = something GROUP BY 1 ) sub LEFT JOIN LATERAL foo(sub.arr) f ON true;
하위 쿼리는 각 dataid에 대한 데이터 배열을 생성하고 LATERAL JOIN을 사용하여 foo 함수와 조인합니다. 이렇게 하면 함수가 한 번만 호출되고 결과가 하위 쿼리 데이터와 결합됩니다.
쿼리 최적화
foo() 함수가 no를 반환할 수 있는 경우 행, LEFT JOIN LATERAL ... ON true를 사용하면 조인 왼쪽의 모든 행이 유지됩니다. 그렇지 않은 경우 CROSS JOIN LATERAL foo(sub.arr) 또는 단축형인 foo(sub.arr)를 사용하여 결과가 없는 행을 제외하는 것이 좋습니다.
이 접근 방식은 여러 함수 호출을 방지할 뿐만 아니라 성능을 향상하고 쿼리를 단순화합니다. , 특히 대규모 데이터세트로 작업할 때 더욱 그렇습니다.
위 내용은 LATERAL JOIN은 PostgreSQL에서 배열 인수를 사용하여 여러 세트 반환 함수 호출을 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!