> 데이터 베이스 > MySQL 튜토리얼 > SQL DISTINCT 마스터하기: 중복 제거를 간단하게 만들기

SQL DISTINCT 마스터하기: 중복 제거를 간단하게 만들기

Barbara Streisand
풀어 주다: 2024-12-27 06:52:10
원래의
594명이 탐색했습니다.

Mastering SQL DISTINCT: Removing Duplicates Made Simple

SQL에서 DISTINCT 키워드의 목적은 무엇인가요?

SQL의 DISTINCT 키워드는 쿼리 결과 집합에서 중복 행을 제거하는 데 사용됩니다. 쿼리가 지정된 열에 대해 고유한 레코드만 반환하도록 합니다.


DISTINCT는 어떻게 작동하나요?

SELECT 쿼리가 데이터를 검색할 때 출력에 중복된 행이 있을 수 있습니다. DISTINCT 키워드를 추가하면 SQL은 이러한 중복 항목을 필터링하여 지정된 열에 있는 각각의 고유한 값 조합을 한 번만 유지합니다.


구문:

SELECT DISTINCT column1, column2, ...
FROM table_name;
로그인 후 복사

:

1. 중복 제거

테이블을 고려해보세요. 직원:

EmployeeID Department
1 HR
2 IT
3 HR
4 Sales

쿼리:

SELECT DISTINCT Department
FROM Employees;
로그인 후 복사

결과:

Department
HR
IT
Sales

여기서 부서 열의 중복 항목을 제거합니다.


2. 독특한 조합 선택

다른 테이블 주문을 고려하십시오.

OrderID CustomerID ProductID
101 1 A
102 1 B
103 1 A
104 2 C

쿼리:

SELECT DISTINCT CustomerID, ProductID
FROM Orders;
로그인 후 복사

결과:

CustomerID ProductID
1 A
1 B
2 C

여기서 DISTINCT는 CustomerID와 ProductID의 조합을 기반으로 중복 행을 필터링합니다.


DISTINCT를 사용해야 하는 경우

  1. 고유한 가치를 찾으려면:

    하나의 컬럼 또는 컬럼 조합의 고유값을 모두 알고 싶을 때.

    예: 인벤토리의 모든 개별 제품 카테고리 나열.

  2. 중복 제거:

    분석이나 보고에 결과 집합의 중복 행이 필요하지 않은 경우

    예: 직원 데이터베이스에서 고유한 부서 이름 가져오기.

  3. 데이터 정리용:

    중복을 제거하여 깨끗한 데이터 세트를 준비하는 데 도움이 됩니다.


DISTINCT의 한계

  1. 성능에 미치는 영향:

    SQL이 중복 항목을 필터링하기 위해 행을 스캔하고 비교해야 하므로 DISTINCT를 사용하면 특히 대규모 데이터 세트에서 쿼리 속도가 느려질 수 있습니다.

  2. 조건부 중복 제거에는 적합하지 않음:

    조건부 중복 제거(예: 각 고유 값에 대해 최신 행 유지)를 원하는 경우 ROW_NUMBER()와 같은 다른 기술이 필요합니다.


DISTINCT 사용 팁

  1. 쿼리 실행에 오버헤드가 추가될 수 있으므로 항상 필요한 경우에만 DISTINCT를 사용하세요.
  2. 복잡한 필터링의 경우 집계(GROUP BY) 또는 분석 기능과 같은 대안을 고려하세요.

결론

DISTINCT 키워드는 SQL 쿼리 결과에서 중복 행을 제거하는 간단하면서도 강력한 도구입니다. 출력에 고유한 값만 포함되므로 데이터 보고 및 분석 작업에 이상적입니다. 그러나 성능과 정확성의 균형을 맞추려면 신중하게 사용하세요.

위 내용은 SQL DISTINCT 마스터하기: 중복 제거를 간단하게 만들기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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