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

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

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-23 22:37:11481검색

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

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