>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL 테이블 함수에서 매개변수화된 ORDER BY 및 LIMIT 절을 효율적으로 구현하려면 어떻게 해야 합니까?

PostgreSQL 테이블 함수에서 매개변수화된 ORDER BY 및 LIMIT 절을 효율적으로 구현하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-31 08:22:13434검색

How Can I Efficiently Implement Parameterized ORDER BY and LIMIT Clauses in a PostgreSQL Table Function?

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

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