동일한 SELECT 문에서 DISTINCT 및 ORDER BY 사용
MonitoringJob 테이블에서 Category 열을 검색하고 SELECT 문을 실행한 후 CreationDate 열의 결과를 내림차순으로 정렬하면 데이터베이스가 중복된 값을 반환할 수 있습니다. 지정된 순서를 유지하면서 중복을 제거하려면 DISTINCT 키워드를 활용할 수 있습니다. 그러나 DISTINCT만으로는 충분하지 않을 수 있습니다.
제공된 예에서 DISTINCT 키워드 자체를 사용하면 문제가 해결되지 않습니다. 왜냐하면 ORDER BY 절이 중복 값이 포함된 CreationDate 열에 의존하기 때문입니다. 이 문제를 해결하기 위해 MAX()와 같은 집계 함수를 DISTINCT 키워드와 결합하여 중복 항목을 제외하면서 특정 열을 기준으로 결과를 정렬할 수 있습니다. 또한 DISTINCT 연산에 사용된 열을 기반으로 고유한 범주를 생성하려면 GROUP BY 절이 필요합니다.
적절한 해결 방법은 다음과 같습니다.
SELECT DISTINCT Category, MAX(CreationDate) FROM MonitoringJob GROUP BY Category ORDER BY MAX(CreationDate) DESC, Category
이 수정된 문은 중복을 보장합니다. MAX(CreationDate) 열을 기준으로 정렬한 다음 범주별로 정렬하여 원하는 순서를 유지하면서 제거됩니다. 결과적으로 최신 CreationDate 값을 기준으로 내림차순으로 고유 카테고리를 나열하여 원하는 출력을 얻을 수 있습니다.
위 내용은 SQL SELECT 문에서 순서를 유지하면서 중복 행을 제거하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!