> 데이터 베이스 > MySQL 튜토리얼 > PostgreSQL의 LATERAL JOIN은 배열 인수에 대한 다중 함수 호출을 어떻게 최적화할 수 있습니까?

PostgreSQL의 LATERAL JOIN은 배열 인수에 대한 다중 함수 호출을 어떻게 최적화할 수 있습니까?

Patricia Arquette
풀어 주다: 2024-12-26 20:52:10
원래의
157명이 탐색했습니다.

How Can PostgreSQL's LATERAL JOIN Optimize Multiple Function Calls on Array Arguments?

배열 인수에 대한 다중 함수 호출을 위한 쿼리 최적화

Postgres에서는 배열 인수에 대해 함수를 여러 번 호출하는 것이 비효율적일 수 있습니다. , 특히 함수가 여러 열을 반환하는 경우. 이 문제를 해결하기 위한 쿼리 최적화 전략을 살펴보겠습니다.

주어진 매개변수로 행 배열을 처리하고 행 집합과 새 열을 반환하는 foo 함수를 생각해 보세요.

CREATE OR REPLACE FUNCTION foo(data data[], parameter int) RETURNS SETOF enhanceddata AS
...
로그인 후 복사

처음에 이 기능은 다음을 사용하여 단일 데이터 세트에 대해 작동합니다.

SELECT * FROM foo( (SELECT ARRAY_AGG(data) FROM datatable GROUP BY dataid WHERE dataid = something), 1) 
로그인 후 복사

그러나 목표는 여러 그룹에 대해 작동하도록 만드는 것입니다. dataid 매개변수를 지정하지 않고 데이터를 저장합니다.

한 가지 접근 방식은 하위 쿼리를 사용하여 데이터를 배열로 집계한 다음 foo 함수에 전달하는 것입니다.

SELECT dataid, (foo(ARRAY_AGG(data)),1).*
FROM dataset
WHERE dataid = something -- only testing on 1
GROUP BY dataid
로그인 후 복사

이것이 논리적으로 보일 수 있지만 , 각 데이터 행에 대해 하나씩 foo를 여러 번 호출하는 문제가 발생합니다.

측면 조인 사용 최적화

이 쿼리를 최적화하기 위해 PostgreSQl LATERAL JOIN을 사용할 수 있습니다. 이 강력한 기술은 하위 쿼리 결과와 다른 테이블의 행 사이에 행 기반 데카르트 곱을 생성합니다. 이 경우 하위 쿼리는 데이터를 배열로 집계하고 측면 조인은 집계된 배열의 각 행에 대해 foo를 한 번씩 실행합니다.

PostgreSQL 9.3 이상을 사용하여 다음 쿼리는 여러 함수 호출을 최적화합니다.

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;
로그인 후 복사

LEFT JOIN LATERAL은 왼쪽 테이블(하위 쿼리)의 모든 행이 보존되지 않도록 보장합니다. 행은 foo에 의해 반환됩니다. 함수가 행을 반환할 수 없는 경우 이것이 선호되는 구문입니다.

항상 결과를 반환하는 함수의 경우 단순화된 구문을 사용할 수 있습니다:

CROSS JOIN LATERAL foo(sub.arr)
로그인 후 복사

또는 이에 상응하는 약어:

, foo(sub.arr)
로그인 후 복사

Postgres 매뉴얼에서 강조한 것처럼 LATERAL JOIN을 사용하면 foo와 같은 집합 반환 기능으로 쿼리가 최적화됩니다. 이 기술은 불필요한 기능 평가를 발생시키지 않고 여러 데이터 그룹을 효율적으로 처리합니다.

위 내용은 PostgreSQL의 LATERAL JOIN은 배열 인수에 대한 다중 함수 호출을 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿