>데이터 베이스 >MySQL 튜토리얼 >SQL에서 각 그룹의 상위 2개 점수를 검색하는 방법은 무엇입니까?

SQL에서 각 그룹의 상위 2개 점수를 검색하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-03 05:21:37838검색

How to Retrieve the Top Two Scores for Each Group in SQL?

SQL에서 개별 그룹의 상위 2개 점수 검색

관계형 데이터베이스의 경우 대규모 데이터 세트에서 의미 있는 데이터를 추출하려면 레코드를 기반으로 그룹화하는 경우가 많습니다. 특정 특성에 대해. 그룹화된 집합에서 데이터를 검색할 때 집계 함수를 사용하여 각 그룹 내에서 가장 높은 값이나 가장 낮은 값을 얻는 것이 일반적입니다. 그런데 각 그룹의 상위 N개 행을 선택해야 한다면 어떻게 해야 할까요?

학생 이름과 해당 점수가 포함된 다음 표를 고려하세요.

NAME SCORE
willy 1
willy 2
willy 3
zoe 4
zoe 5
zoe 6

그룹화를 위한 집계 기능은 당신은 각 이름에 대해 가장 높은 점수를 얻을 수 있습니다. 각 학생의 상위 2개 점수를 검색하려면 다른 접근 방식이 필요합니다.

다음 쿼리는 해당 그룹 내에서 각 학생의 점수 순위를 추적하는 하위 쿼리를 사용하여 이를 달성합니다.

SELECT *
FROM test s
WHERE 
        (
            SELECT COUNT(*) 
            FROM test f
            WHERE f.name = s.name AND 
                  f.score >= s.score
        ) <= 2

쿼리 분석:

  • 외부 쿼리, SELECT * FROM test s는 테스트 테이블에서 모든 행을 검색하고 s로 별칭을 지정합니다.
  • 괄호로 묶인 하위 쿼리는 각 학생의 점수 순위를 계산합니다.

    • SELECT COUNT(*) FROM test f: 이 부분은 이름(f.name)이 현재 행의 이름과 일치하는 테스트 테이블의 행 수를 계산합니다. (s.name) 및 점수(f.score)가 현재 행의 점수(s.score)보다 크거나 같습니다.
  • WHERE 절은 다음에 필터를 적용합니다. 하위 쿼리에 의해 결정된 순위가 다음보다 작거나 같은 행만 선택하는 외부 쿼리 2.

출력:

이 쿼리를 실행하면 다음 결과가 반환됩니다.

NAME SCORE
willy 2
willy 3
zoe 5
zoe 6

이 쿼리는 상위 2개를 효과적으로 검색합니다. 간단한 MAX() 집계를 사용하는 것에 비해 학생의 성과에 대한 더 포괄적인 보기를 제공합니다.

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

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