> 데이터 베이스 > MySQL 튜토리얼 > 필터링을 통해 Oracle에서 상위 10개 레코드를 효율적으로 선택하는 방법은 무엇입니까?

필터링을 통해 Oracle에서 상위 10개 레코드를 효율적으로 선택하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2025-01-18 15:31:16
원래의
500명이 탐색했습니다.

How to Efficiently Select the Top 10 Records in Oracle with Filtering?

Oracle 데이터베이스의 상위 10개 레코드를 효율적으로 필터링: 하위 쿼리 및 ROWNUM 기술

이 글은 HISTORY 테이블에서 STORAGE_GB 기준으로 정렬하고 특정 조건에 맞는 행을 제외하고 최종적으로 처음 10개의 레코드만 선택하는 문제를 해결하는 것을 목표로 합니다. 정렬하기 전에 ROWNUM을 직접 사용하여 결과를 제한하면 문제가 발생할 수 있습니다.

하위 쿼리를 사용한 솔루션:

해결책은 정렬 순서를 포함한 모든 기준에 따라 필요한 레코드를 선택하는 하위 쿼리를 만드는 것입니다. 그런 다음 이 하위 쿼리를 데이터 소스로 사용하고 ROWNUM을 사용하여 처음 10개 행을 선택합니다.

<code class="language-sql">SELECT *
FROM (
  SELECT DISTINCT
    APP_ID,
    NAME,
    STORAGE_GB,
    HISTORY_CREATED,
    TO_CHAR(HISTORY_DATE, 'DD.MM.YYYY') AS HISTORY_DATE
  FROM HISTORY
  WHERE
    STORAGE_GB IS NOT NULL
    AND APP_ID NOT IN (
      SELECT APP_ID
      FROM HISTORY
      WHERE TO_CHAR(HISTORY_DATE, 'DD.MM.YYYY') = '06.02.2009'
    )
  ORDER BY STORAGE_GB DESC
)
WHERE ROWNUM <= 10;</code>
로그인 후 복사

최적화를 위해 EXISTS 사용:

대규모 데이터 세트의 경우 Oracle의 ROWNUM은 효율적이지 않습니다. 성능을 향상하려면 NOT IN 대신 EXISTS 연산자를 사용하는 것이 좋습니다.

<code class="language-sql">SELECT DISTINCT
  APP_ID,
  NAME,
  STORAGE_GB,
  HISTORY_CREATED,
  TO_CHAR(HISTORY_DATE, 'DD.MM.YYYY') AS HISTORY_DATE
FROM HISTORY
WHERE
  STORAGE_GB IS NOT NULL
  AND NOT EXISTS (
    SELECT 1
    FROM HISTORY
    WHERE
      APP_ID = APP_ID
      AND TO_CHAR(HISTORY_DATE, 'DD.MM.YYYY') = '06.02.2009'
  )
ORDER BY STORAGE_GB DESC
FETCH FIRST 10 ROWS ONLY;</code>
로그인 후 복사

(참고: LIMIT 10은 Oracle에서 직접 지원되지 않습니다. 대신 FETCH FIRST 10 ROWS ONLY을 사용해야 합니다.)

위 방법을 통해 오라클 데이터베이스에서 조건에 맞는 상위 10개 레코드를 효율적으로 필터링할 수 있습니다. EXISTS을 사용하여 버전을 선택하면 특히 대규모 데이터 세트를 처리할 때 쿼리 효율성이 크게 향상될 수 있습니다.

위 내용은 필터링을 통해 Oracle에서 상위 10개 레코드를 효율적으로 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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