PostgreSQL의 테이블 함수를 활용하면 효율적인 데이터 조작 및 검색이 가능합니다. 그러나 대규모 데이터세트를 처리할 때는 결과를 효과적으로 처리하기 위해 정렬 및 페이지 매김을 적용하는 것이 중요합니다.
다음 시나리오를 고려해보세요. stuff:
CREATE OR REPLACE FUNCTION getStuff(param character varying) RETURNS SETOF stuff AS $BODY$ select * from stuff where col = $BODY$ LANGUAGE sql;
처음에는 다음과 같이 함수를 호출합니다.
select * from getStuff('hello');
그러나, 성능을 최적화하려면 ORDER BY 절과 LIMIT 절을 적용해야 합니다. 불행하게도 다음과 같은 쿼리를 실행하면
select * from getStuff('hello') order by col2 limit 100;
stuff 테이블에서 모든 행을 검색한 다음 순서를 지정하고 제한하므로 처리가 비효율적입니다.
게다가 PostgreSQL은 값만 전송할 수 있으므로 ORDER BY 인수를 SQL 언어 함수에 전달하는 고유한 방법입니다. plpgsql 함수 내에서 쿼리를 구성하고 EXECUTE를 통해 실행하는 것은 대안적인 접근 방식이지만 가장 우아한 솔루션은 아닙니다.
다행히 plpgsql 함수는 다음과 같은 경우에 효과적인 솔루션을 제공합니다. 이 시나리오. ORDER BY 및 LIMIT에 대한 추가 매개변수를 허용하도록 getStuff 함수를 수정할 수 있습니다.
CREATE OR REPLACE FUNCTION getStuff(param character varying, orderby character varying, _limit int) RETURNS SETOF stuff AS $func$ BEGIN RETURN QUERY EXECUTE ' SELECT * FROM stuff WHERE col = ORDER BY ' || quote_ident(_orderby) || ' ASC LIMIT ' USING _param, _limit; END $func$ LANGUAGE plpgsql;
이제 원하는 매개변수로 함수를 호출할 수 있습니다.
SELECT * FROM getStuff('hello', 'col2', 100);
RETURN QUERY EXECUTE 문은 함수 내에서 쿼리 결과를 효율적으로 검색합니다.
위 내용은 PostgreSQL 테이블 함수에서 매개변수화된 ORDER BY 및 LIMIT 절을 효율적으로 구현하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!