>데이터 베이스 >MySQL 튜토리얼 >Access SQL에서 각 사용자의 상위 N 레코드를 검색하는 방법은 무엇입니까?

Access SQL에서 각 사용자의 상위 N 레코드를 검색하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-07 17:32:41909검색

How to Retrieve the Top N Records for Each User in Access SQL?

Access SQL: 사용자별 상위 N개 레코드 추출

이 가이드에서는 단일 SQL 쿼리를 사용하여 Access 데이터베이스 내 각 사용자의 가장 최근 기록 상위 3개를 검색하는 방법을 보여줍니다. 이 작업에는 중첩 쿼리를 활용하겠습니다.

데이터베이스 구조

저희 데이터베이스는 두 개의 테이블로 구성됩니다.

  • 사용자 테이블: LoginID, Forename, Surname, DOB, Guardian Forename, Guardian Surname, Telephone Number
  • 진행표: ProgressID, LoginID, Score, Date Taken

해결책: 중첩 쿼리

단일 쿼리 내에서 TOP N을 사용하는 간단한 접근 방식은 이 특정 요구 사항(각 그룹의 상위 N개 검색)에 대해 Access SQL에서 직접 지원되지 않습니다. 대신 이를 달성하기 위해 하위 쿼리를 사용합니다.

내부 쿼리는 각 Date Taken:LoginID에 대한 상위 3개의

값을 식별합니다.
<code class="language-sql">SELECT TOP 3 PR2.[Date Taken]
FROM Progress AS PR2
WHERE PR2.LoginID = PR1.LoginID
ORDER BY PR2.[Date Taken] DESC</code>

이 결과 집합은 외부 쿼리의 IN 절에서 Progress 테이블을 필터링하는 데 사용됩니다.

<code class="language-sql">SELECT PR1.LoginID, PR1.Score, PR1.[Date Taken]
FROM Progress AS PR1
WHERE PR1.[Date Taken] IN (
    SELECT TOP 3 PR2.[Date Taken]
    FROM Progress AS PR2
    WHERE PR2.LoginID = PR1.LoginID
    ORDER BY PR2.[Date Taken] DESC
)
ORDER BY PR1.LoginID, PR1.[Date Taken] DESC;</code>

이 최종 쿼리는 LoginID, LoginID 순으로 내림차순(가장 최근 순)으로 깔끔하게 정렬된 각 Date Taken에 대한 3개의 최신 레코드를 효율적으로 반환합니다. 이렇게 하면 Access SQL 내에서 그룹화된 데이터에 TOP N을 직접 적용하는 데 따른 제한을 피할 수 있습니다.

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

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