SQL의 최대값 하위 쿼리
이 쿼리에서는 다른 열의 최대값을 기반으로 열에 해당하는 값을 검색하려고 합니다. . 원래 접근 방식에서는 GROUP BY 문을 사용하지만 최대 동영상 ID만 안정적으로 가져오며 다른 열의 관련 데이터는 가져오지 않습니다.
이 문제를 해결하려면 카테고리별로 고유한 최대 동영상 ID를 식별하는 하위 쿼리를 활용하는 것이 좋습니다. . 아래의 수정된 쿼리는 이 접근 방식을 따릅니다.
SELECT * FROM videos WHERE video_id IN ( SELECT DISTINCT MAX(video_id) FROM videos GROUP BY video_category ) ORDER BY video_category ASC
이 쿼리에서는 최대 비디오 ID 집합을 분리하기 위해 하위 쿼리가 사용됩니다. 그런 다음 테이블은 이 세트를 사용하여 필터링되어 해당 최대 비디오 ID에 대한 모든 열을 검색합니다. IN 연산자를 활용하고 결과를 연결함으로써 이 쿼리는 원하는 값을 효율적으로 가져옵니다.
또는 아래와 같이 조인 작업을 사용하여 동일한 결과를 얻을 수 있습니다.
SELECT s.video_id ,s.video_category ,s.video_url ,s.video_date ,s.video_title ,s.short_description FROM videos s JOIN (SELECT MAX(video_id) AS id FROM videos GROUP BY video_category) max ON s.video_id = max.id
이 접근 방식은 조인을 활용하여 최대 동영상 ID 행을 동영상 테이블의 해당 행과 일치시키고 각 최대 동영상 ID에 대한 전체 열 집합을 검색합니다. 두 솔루션 모두 각 카테고리의 최대 비디오 ID와 연관된 값을 캡처하여 문제를 효과적으로 해결합니다.
위 내용은 SQL 하위 쿼리에서 최대값 및 관련 열을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!