>  기사  >  데이터 베이스  >  MySQL에서 고유 인덱스를 사용하여 테이블에서 중복을 제거하는 방법은 무엇입니까?

MySQL에서 고유 인덱스를 사용하여 테이블에서 중복을 제거하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-25 07:46:02732검색

How to Remove Duplicates from a Table Using a Unique Index in MySQL?

고유 인덱스로 중복 제거

중복 레코드가 있는 큰 테이블이 있고 고유 인덱스를 생성하여 이를 제거하고 싶다면, 잠재적인 결과를 알고 있어야 합니다.

이미 중복이 포함된 테이블에 고유 인덱스를 추가하려고 하면 중복 키 오류로 인해 작업이 실패합니다. 이는 고유 인덱스가 포함된 데이터의 고유성을 강화하기 때문입니다.

그러나 이 문제에 대한 해결 방법이 있습니다. 고유 인덱스를 생성할 때 IGNORE 수정자를 사용할 수 있습니다. 이는 MySQL이 중복된 값을 무시하고 고유한 값만 삽입하도록 지시합니다.

<code class="sql">ALTER TABLE mytable ADD UNIQUE INDEX myindex (A, B, C, D) IGNORE;</code>

IGNORE 수정자를 사용하면 중복된 값이 제거되지만 어떤 행이 유지될지 지정하지 않는다는 점에 유의하는 것이 중요합니다. . MySQL은 각 중복 항목에 대해 임의로 하나의 행을 선택하고 나머지는 삭제합니다.

MySQL 버전 5.7.4 이상을 사용하는 경우 ALTER TABLE에 대한 IGNORE 수정자가 제거되어 오류가 발생합니다. 이 경우 다음 해결 방법을 사용할 수 있습니다.

  1. 데이터를 임시 테이블에 복사합니다.
  2. 원본 테이블을 자릅니다.
  3. UNIQUE 인덱스를 생성합니다.
  4. INSERT IGNORE를 사용하여 원래 테이블에 데이터를 다시 삽입합니다.
<code class="sql">CREATE TABLE tmp_data SELECT * FROM mytable;
TRUNCATE TABLE mytable;
ALTER TABLE mytable ADD UNIQUE INDEX myindex (A, B, C, D);
INSERT IGNORE INTO mytable SELECT * from tmp_data;
DROP TABLE tmp_data;</code>

INSERT IGNORE를 사용하면 중복 값을 무시하고 고유한 값만 삽입합니다. 데이터가 삽입되면 임시 테이블을 삭제할 수 있습니다.

위 내용은 MySQL에서 고유 인덱스를 사용하여 테이블에서 중복을 제거하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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