집 >데이터 베이스 >MySQL 튜토리얼 >필터링을 통해 Oracle에서 상위 10개 레코드를 효율적으로 선택하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!