> 데이터 베이스 > MySQL 튜토리얼 > SQL을 사용하여 각 그룹에서 가장 나이 많은 사람을 찾는 방법은 무엇입니까?

SQL을 사용하여 각 그룹에서 가장 나이 많은 사람을 찾는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2025-01-23 22:37:11
원래의
515명이 탐색했습니다.

How to Find the Oldest Person in Each Group Using SQL?

SQL을 활용하여 그룹별 최고령자를 효율적으로 식별

데이터베이스 쿼리를 수행하려면 특정 그룹 내에서 최대값을 찾아야 하는 경우가 많습니다. 이 예는 person, groupage 열이 있는 테이블에서 각 그룹의 가장 나이가 많은 사람을 찾아내는 방법을 보여줍니다.

해결책:

이 접근 방식은 LEFT JOIN을 활용하여 그룹 내 각 개인의 연령을 비교합니다. 일치 항목이 없는 행은 해당 그룹에서 가장 나이가 많은 사람을 나타냅니다.

구현:

<code class="language-sql">SELECT o.*
FROM Persons o
LEFT JOIN Persons b ON o.Group = b.Group AND o.Age < b.Age
WHERE b.Age IS NULL;</code>
로그인 후 복사

설명:

  • Persons o: Persons 테이블의 별칭은 o("oldest"의 경우)입니다.
  • LEFT JOIN Persons b: LEFT JOINPersons 별칭이 지정된 b 테이블을 사용하여 수행됩니다("더 큰 연령"의 경우). 이는 o의 각 행을 동일한 그룹(o.Group = b.Group)의 더 큰 연령(o.Age < b.Age)을 갖는 행과 조인합니다.
  • WHERE b.Age IS NULL: 이 중요한 절은 결과를 필터링합니다. o의 사람이 b에 일치하는 항목이 없으면(b.Age이 NULL임을 의미) 그룹에 나이가 많은 사람이 없다는 의미입니다. 따라서 각 그룹에서 가장 나이가 많은 사람만 선정됩니다.

중요 고려 사항:

  • INNER JOIN을 사용하면 구성원이 한 명뿐인 그룹에서 가장 나이 많은 사람이 잘못 누락됩니다.
  • 이 방법은 이러한 유형의 쿼리에 매우 효율적이고 널리 권장되는 기술입니다. 유사한 접근법은 "SQL 안티패턴 볼륨 1: 데이터베이스 프로그래밍의 함정 방지"에서 논의됩니다.

위 내용은 SQL을 사용하여 각 그룹에서 가장 나이 많은 사람을 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿