>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL 테이블 함수의 결과를 효율적으로 정렬하고 제한하는 방법은 무엇입니까?

PostgreSQL 테이블 함수의 결과를 효율적으로 정렬하고 제한하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-05 02:33:40659검색

How to Efficiently Order and Limit Results from a PostgreSQL Table Function?

PostgreSQL 매개변수화된 테이블 함수의 순서 지정 및 제한

질문:

활용할 때 어떻게 효율적으로 결과를 정렬하고 제한할 수 있습니까? getStuff와 같은 SQL 테이블 함수? 함수 외부에서 주문 및 제한하거나 plpgsql을 사용하는 것이 고려되고 있습니다. 더 나은 접근 방식이 있습니까?

답변:

처음 모양에도 불구하고 plpgsql 함수는 보다 복잡한 시나리오를 처리하는 데 선호되는 옵션입니다. 쿼리 플래너가 외부 쿼리 컨텍스트 내에서 코드를 완전히 최적화할 수 없는 plpgsql 함수가 중첩된 경우에만 성능이 저하될 수 있습니다.

과도한 CASE를 방지하는 단순화된 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);

참고:

  • RETURN QUERY EXECUTE를 사용하여 쿼리 결과를 단일로 반환
  • quote_ident()를 사용하여 식별자가 SQLi 방지인지 확인하세요.
  • USING을 활용하여 매개변수 값을 전달하고 캐스팅 및 SQLi를 방지하세요.
  • 매개변수와 열 간의 이름 지정 충돌을 방지하세요. names.
  • 초기 편집 함수는 부모를 반환하지만 SETOF 항목을 반환하도록 선언되었기 때문에 실패합니다. 대신 RETURNS TABLE을 사용해 보세요.

위 내용은 PostgreSQL 테이블 함수의 결과를 효율적으로 정렬하고 제한하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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