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 중국어 웹사이트의 기타 관련 기사를 참조하세요!