집 >데이터 베이스 >MySQL 튜토리얼 >SQL에서 고유하고 정렬된 결과를 얻기 위해 DISTINCT와 ORDER BY를 결합하는 방법은 무엇입니까?
동일한 SELECT 문에서 DISTINCT 및 ORDER BY를 사용하는 방법
실행된 쿼리는 종종 중복 데이터를 반환하고 ORDER BY를 사용하여 해당 데이터를 정렬합니다. 이러한 중복 항목을 제거하는 것만으로는 충분하지 않을 수 있습니다. 그러나 단일 SELECT 문에 DISTINCT와 ORDER BY를 결합하면 개발자는 원하는 순서를 유지하면서 효율적으로 중복을 제거할 수 있습니다.
이 문제를 해결하려면 ORDER BY 절에 SELECT 절에 사용된 열이 포함되어야 합니다. DISTINCT를 사용하면 지정된 열을 기준으로 결과를 그룹화하여 효과적으로 중복 항목을 제거합니다. 그러나 ORDER BY 절이 DISTINCT에 포함되지 않은 열을 참조하는 경우 순서가 SELECT 열에서 동일한 값을 가진 모든 행을 잘못 그룹화하여 결과가 중복됩니다.
해결책:
해결 방법 이 문제에서는 쿼리에서 MAX()와 같은 집계 함수를 사용하여 원하는 열(이 경우 CreationDate)을 기준으로 정렬해야 합니다. 또한 DISTINCT 열(Category)을 기준으로 결과를 그룹화하기 위해 GROUP BY 절이 추가되었습니다. 이 조합을 사용하면 결과 순서를 유지하면서 중복 항목을 제거할 수 있습니다. 수정된 쿼리는 다음과 같습니다.
SELECT DISTINCT Category, MAX(CreationDate) FROM MonitoringJob GROUP BY Category ORDER BY MAX(CreationDate) DESC, Category
이 수정된 쿼리는 Category에서 중복 항목을 제거하고 CreationDate를 기준으로 내림차순으로 정렬한 다음 Category로 정렬하여 원하는 결과를 출력합니다.
위 내용은 SQL에서 고유하고 정렬된 결과를 얻기 위해 DISTINCT와 ORDER BY를 결합하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!