> 데이터 베이스 > MySQL 튜토리얼 > SQL SELECT 문에서 순서를 유지하면서 중복 행을 제거하려면 어떻게 해야 합니까?

SQL SELECT 문에서 순서를 유지하면서 중복 행을 제거하려면 어떻게 해야 합니까?

DDD
풀어 주다: 2025-01-07 09:21:42
원래의
691명이 탐색했습니다.

How Can I Remove Duplicate Rows While Maintaining Order in a SQL SELECT Statement?

동일한 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿