테이블 함수의 PostgreSQL 매개변수화된 정렬 기준/제한
이 질문은 PostgreSQL 테이블 함수 내에서 정렬 기준 및 제한 절을 통합하기 위한 옵션을 탐색합니다. 외부에서 주문하고 슬라이싱하는 것의 잠재적인 비효율성을 강조합니다. function.
제시된 솔루션 중 하나는 plpgsql 함수를 사용하는 것입니다. 이를 통해 EXECUTE를 통해 보다 복잡한 쿼리 구성 및 실행이 가능합니다. 이 접근 방식은 쿼리에 대한 더 큰 유연성과 제어 기능을 제공합니다.
이를 구현하려면 수정된 plpgsql 함수를 생성할 수 있습니다.
CREATE OR REPLACE FUNCTION get_stuff(_param text, _orderby text, _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 get_stuff('hello', 'col2', 100);
이 솔루션은 식별자에 quote_ident()를 사용하고 매개변수 값에 USING 절을 사용하여 SQL 주입 취약점을 방지합니다. 또한 RETURN QUERY EXECUTE는 쿼리 결과를 효율적으로 반환합니다.
plpgsql 함수는 단순한 SQL 함수보다 더 장황할 수 있지만 더 복잡한 쿼리에는 더 뛰어난 유연성과 성능을 제공합니다.
위 내용은 PostgreSQL 테이블 함수에서 매개변수화된 ORDER BY 및 LIMIT 절을 효율적으로 구현하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!