>데이터 베이스 >MySQL 튜토리얼 >Oracle SQL에서 상위 5개 열 값을 검색하는 방법은 무엇입니까?

Oracle SQL에서 상위 5개 열 값을 검색하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-09 13:47:46305검색

How to Retrieve the Top 5 Column Values in Oracle SQL?

Oracle SQL: 상위 5개 최고 값 추출

많은 데이터베이스 작업에서는 열의 최고 또는 최저 값을 기준으로 특정 수의 행을 검색해야 합니다. 이는 최고 성과자를 식별하거나 보고서를 작성하는 데 특히 유용합니다. 이 문서에서는 열에서 상위 5개 값을 검색하는 여러 Oracle SQL 방법을 보여줍니다.

분석 기능 사용: RANK()DENSE_RANK()

분석 기능은 효율적인 행 순위 지정을 제공합니다. RANK()은 지정된 기준에 따라 고유한 순위를 할당하는 반면, DENSE_RANK()는 유사한 기능을 제공하지만 동점에 대한 순위 차이를 제거합니다.

RANK()을 사용하여 "emp" 테이블의 "sal" 열에서 상위 5개 급여를 검색하려면:

<code class="language-sql">SELECT *
FROM (
    SELECT empno, sal,
           RANK() OVER (ORDER BY sal DESC) AS rnk
    FROM emp
)
WHERE rnk <= 5;</code>

활용 ROW_NUMBER()

ROW_NUMBER() 함수는 순서에 관계없이 각 행에 일련 번호를 할당합니다. 결과를 특정 행 수로 제한할 수 있습니다.

ROW_NUMBER()을 사용하여 상위 5개 급여를 받는 방법은 다음과 같습니다.

<code class="language-sql">SELECT *
FROM (
    SELECT empno, sal,
           ROW_NUMBER() OVER (ORDER BY sal DESC) AS rnk
    FROM emp
)
WHERE rnk <= 5;</code>

대체 접근 방식: ROWNUM 유사 열

ROWNUM 의사 열은 쿼리 결과의 물리적 행 번호를 제공합니다. 그러나 잠재적인 불일치로 인해 결과를 제한하는 데 사용하는 것은 일반적으로 권장되지 않습니다.

ROWNUM을 사용한 예:

<code class="language-sql">SELECT *
FROM (
    SELECT empno, sal
    FROM emp
    ORDER BY sal DESC
)
WHERE ROWNUM <= 5;</code>

올바른 방법 선택

가장 좋은 접근 방식은 특정 요구 사항과 데이터 특성에 따라 다릅니다.

  • RANK()DENSE_RANK()은 동점인 경우에도 순위 순서를 유지합니다.
  • ROW_NUMBER() 특정 행 수를 보장하지만 동점인 결과를 임의로 자를 수도 있습니다.
  • ROWNUM 신뢰성이 떨어지므로 주의해서 사용해야 합니다.

Oracle SQL에서 정확하고 일관된 데이터 검색을 위해서는 이러한 방법을 신중하게 고려하는 것이 중요합니다.

위 내용은 Oracle SQL에서 상위 5개 열 값을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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