집 >데이터 베이스 >MySQL 튜토리얼 >Oracle SQL에서 상위 5개 열 값을 검색하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!