집 >데이터 베이스 >MySQL 튜토리얼 >SQL에서 주어진 ID에 대한 가장 최근 행을 검색하는 방법은 무엇입니까?
주어진 ID에 대한 가장 최근 행 검색
데이터베이스 테이블에 동일한 ID에 대한 여러 행이 포함되어 있는 경우 가장 최근의 것만 추출해야 합니다. 이 문서에서는 SQL에서 이를 달성하는 방법을 설명합니다.
제공된 테이블을 예로 사용:
+----+---------------------+---------+ | id | signin | signout | +----+---------------------+---------+ | 1 | 2011-12-12 09:27:24 | NULL | | 1 | 2011-12-13 09:27:31 | NULL | | 1 | 2011-12-14 09:27:34 | NULL | | 2 | 2011-12-14 09:28:21 | NULL | +----+---------------------+---------+
ID별로 그룹화된 Aggregate MAX(signin)
각 ID의 최근 로그인 시간을 얻으려면 행을 ID별로 그룹화하고 MAX(signin)로 집계합니다. 그러면 해당 최신 로그인 시간과 함께 ID 목록이 제공됩니다.
SQL 쿼리:
SELECT id, MAX(signin) AS most_recent_signin FROM tbl GROUP BY id
INNER JOIN Against a Subquery
특정 ID에 대한 가장 최근 행 전체를 검색하려면(예: ID=1), ID당 MAX(signin)를 계산하는 하위 쿼리에 대해 INNER JOIN을 사용합니다. 그런 다음 원하는 ID를 기준으로 결과를 필터링합니다.
SQL 쿼리:
SELECT tbl.id, signin, signout FROM tbl INNER JOIN ( SELECT id, MAX(signin) AS maxsign FROM tbl GROUP BY id ) ms ON tbl.id = ms.id AND signin = maxsign WHERE tbl.id=1
위 내용은 SQL에서 주어진 ID에 대한 가장 최근 행을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!