집 >데이터 베이스 >MySQL 튜토리얼 >SQL에서 DISTINCT 및 ORDER BY를 사용하여 고유하게 정렬된 결과를 얻는 방법은 무엇입니까?
고유한 결과를 위해 DISTINCT와 ORDER BY 결합
중복 값이 포함된 데이터세트에 직면했을 때 DISTINCT를 사용하여 중복 항목을 제거하는 것이 필수적일 수 있습니다. 독특한 결과를 얻습니다. 그러나 정렬도 필요한 경우 동일한 SELECT 문에서 ORDER BY를 사용하면 문제가 발생할 수 있습니다.
이 문제를 해결하려면 다음 쿼리를 고려하세요.
SELECT Category FROM MonitoringJob ORDER BY CreationDate DESC
이 쿼리는 데이터를 검색합니다. MonitoringJob 테이블에서 CreationDate 열을 기준으로 내림차순으로 결과를 정렬합니다. 원하는 결과는 최신 생성 날짜를 기준으로 정렬된 고유 카테고리 목록입니다. 그러나 쿼리에서 중복된 값이 생성됩니다.
이 문제를 해결하기 위한 한 가지 시도는 DISTINCT를 사용하는 것일 수 있습니다.
SELECT DISTINCT Category FROM MonitoringJob ORDER BY CreationDate DESC
안타깝게도 DISTINCT는 단일 쿼리에서 ORDER BY와 함께 작동하지 않기 때문에 이 쿼리는 실패합니다.
이 문제를 해결하려면 집계 함수와 GROUP BY 절을 사용할 수 있습니다. 사용됨:
SELECT DISTINCT Category, MAX(CreationDate) FROM MonitoringJob GROUP BY Category ORDER BY MAX(CreationDate) DESC, Category
이 쿼리:
이 접근 방식은 중복을 제거하는 DISTINCT의 기능과 데이터를 정렬하는 ORDER BY 기능을 결합하여 원하는 순서로 정렬된 고유한 결과를 제공합니다.
위 내용은 SQL에서 DISTINCT 및 ORDER BY를 사용하여 고유하게 정렬된 결과를 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!