>데이터 베이스 >MySQL 튜토리얼 >SQL에서 DISTINCT 및 ORDER BY를 사용하여 고유하게 정렬된 결과를 얻는 방법은 무엇입니까?

SQL에서 DISTINCT 및 ORDER BY를 사용하여 고유하게 정렬된 결과를 얻는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-07 09:26:40466검색

How to Get Unique Sorted Results Using DISTINCT and ORDER BY in SQL?

고유한 결과를 위해 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

이 쿼리:

  1. MAX() 집계 함수를 사용하여 각 카테고리의 최신 생성 날짜를 찾습니다.
  2. GROUP BY를 사용하여 카테고리별로 결과를 그룹화하여 고유한 값을 보장합니다.
  3. 최신 생성 날짜를 기준으로 먼저 결과를 정렬합니다. (내림차순) 및 카테고리별.

이 접근 방식은 중복을 제거하는 DISTINCT의 기능과 데이터를 정렬하는 ORDER BY 기능을 결합하여 원하는 순서로 정렬된 고유한 결과를 제공합니다.

위 내용은 SQL에서 DISTINCT 및 ORDER BY를 사용하여 고유하게 정렬된 결과를 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.