>데이터 베이스 >MySQL 튜토리얼 >SQL만 사용하여 MySQL에서 중복 행을 효율적으로 제거하려면 어떻게 해야 합니까?

SQL만 사용하여 MySQL에서 중복 행을 효율적으로 제거하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-24 02:01:13847검색

How Can I Efficiently Remove Duplicate Rows in MySQL Using Only SQL?

SQL을 사용하여 MySQL에서 중복 행 제거

MySQL 데이터베이스의 중복 행은 데이터 불일치 및 성능 문제를 일으킬 수 있습니다. 이 문서에서는 'site_id', 'title' 및 'company' 열을 기반으로 테이블(예: 'jobs')에서 중복 행을 제거하는 데 중점을 둡니다.

복잡한 SQL 쿼리는 중복을 식별할 수 있지만 더 효율적인 방법은 MySQL의 인덱싱 기능을 활용하는 것입니다. 여기에는 중복 행 제거를 자동으로 처리하는 고유 인덱스 생성이 포함됩니다.

고유 인덱스 접근 방식(더 이상 사용되지 않음)

이전에는 ALTER IGNORE TABLE 인덱스와 함께 UNIQUE 문을 사용하는 간단한 솔루션이 있었습니다.

<code class="language-sql">ALTER IGNORE TABLE jobs ADD UNIQUE INDEX idx_name (site_id, title, company);</code>

이 방법은 인덱스 생성 중에 중복 행을 자동으로 삭제했습니다. 그러나 이 접근 방식은 MySQL 5.6에서 더 이상 사용되지 않으며 이후 버전에서는 제거됩니다.

장점(이전 MySQL 버전의 경우):

  • 간단성: 별도의 삭제 문이 필요하지 않습니다.
  • 자동화: 향후 중복 삽입을 방지합니다.
  • 성능 개선: 고유 인덱스로 데이터 검색 속도가 향상됩니다.

최신 MySQL 솔루션(5.7 이상):

MySQL 5.7 이상에서는 ALTER IGNORE TABLE 메서드가 더 이상 지원되지 않습니다. 대신 하위 쿼리와 함께 DELETE 문을 사용하여 중복 항목을 제거하세요. 이를 위해서는 더 복잡한 접근 방식이 필요하지만 현재 MySQL 버전과의 호환성이 보장됩니다. 일반적인 해결 방법은 GROUP BY 절과 HAVING 절을 사용하여 중복 항목을 식별하여 1보다 큰 개수를 필터링한 다음 특정 기준에 따라 추가 행을 삭제하는 것입니다(예: 가장 낮은 ID의 행 유지). 정확한 쿼리는 특정 요구 사항과 테이블 구조에 따라 달라집니다. 이 접근 방식에 대한 자세한 예는 MySQL 설명서를 참조하세요.

위 내용은 SQL만 사용하여 MySQL에서 중복 행을 효율적으로 제거하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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