>데이터 베이스 >MySQL 튜토리얼 >기본 키 없이 SQL 테이블에서 중복 행을 제거하는 방법은 무엇입니까?

기본 키 없이 SQL 테이블에서 중복 행을 제거하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-03 02:35:39375검색

How to Remove Duplicate Rows from a SQL Table Without a Primary Key?

기본 키가 없는 SQL 테이블에서 중복 레코드를 삭제하는 방법

기본 키가 없는 SQL 테이블을 처리할 때 중복 처리 기록이 문제가 될 수 있습니다. 그러나 특정 기준에 따라 중복 항목을 제거하는 효율적인 방법이 있습니다.

다음 시나리오를 고려해 보십시오. 'EmpId', 'EmpName' 및 'EmpSSN' 열이 있는 'employee' 테이블과 일부 레코드가 있습니다. 'EmpId' 및 'EmpSSN' 필드에 중복된 값이 있습니다. 이러한 중복 항목을 제거하려면 다음 쿼리를 활용할 수 있습니다.

DELETE SUB FROM
(SELECT ROW_NUMBER() OVER (PARTITION BY EmpId, EmpName, EmpSSN ORDER BY EmpId) cnt
 FROM employee) SUB
WHERE SUB.cnt > 1

쿼리 이해:

  • 외부 DELETE 문은 'employee'에서 행을 제거합니다. ' 하위 쿼리에서 가져온 정보를 기반으로 하는 테이블입니다.
  • 하위 쿼리는 행을 계산합니다. 'EmpId', 'EmpName' 및 'EmpSSN'의 각 고유 조합에 대한 개수(cnt)입니다.
  • PARTITION BY 절은 각 개별 그룹에 대해 행 개수가 재설정되도록 이러한 필드별로 레코드를 그룹화합니다.
  • ORDER BY 절은 각 그룹 내의 레코드를 정렬하여 첫 번째 행이 원본 레코드인지 확인합니다.
  • 하위 쿼리의 WHERE 절은 cnt가 1보다 큰 행을 필터링하여 중복임을 나타냅니다.
  • 그런 다음 외부 DELETE 문은 FROM 절을 사용하여 하위 쿼리를 가상 테이블(SUB)로 참조하고 삭제합니다. 기본 'employee' 테이블의 행입니다.

이 쿼리는 다음의 고유한 조합을 기반으로 중복 레코드를 효과적으로 제거합니다. 기본 키가 없는 테이블에서 데이터 정리를 효율적으로 수행하는 'EmpId' 및 'EmpSSN'

위 내용은 기본 키 없이 SQL 테이블에서 중복 행을 제거하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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