>데이터 베이스 >MySQL 튜토리얼 >최신을 유지하면서 MySQL에서 중복 레코드를 삭제하는 방법은 무엇입니까?

최신을 유지하면서 MySQL에서 중복 레코드를 삭제하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-16 12:50:03286검색

How to Delete Duplicate Records in MySQL While Keeping the Latest?

최신 데이터를 보존하면서 MySQL에서 중복 레코드 삭제

데이터베이스에서, 특히 고유 식별자가 있는 테이블에서 중복 레코드를 발견하는 것이 일반적입니다. . MySQL에서는 이메일이 중복되는 상황이 발생할 수 있으며, 가장 최근 ID를 가진 최신 이메일만 유지하고 싶을 수 있습니다.

이 문제를 해결하려면 다음 단계를 수행할 수 있습니다.

  1. 중복 이메일 식별: 표에 두 번 이상 나타나는 이메일을 확인합니다.
  2. 각 중복 이메일의 최신 ID 찾기: 각 이메일에 대해 이메일을 중복하는 경우 가장 최근에 삽입된 항목을 나타내는 가장 높은 ID를 검색합니다.
  3. 이전 ID가 있는 중복 항목 삭제: 이전 단계에서 식별된 최신 항목을 제외한 모든 중복 항목을 제거합니다.

구현:

id 및 email 열이 포함된 test라는 이름의 다음 MySQL 테이블을 고려하세요.

| id | email |
|---|---|
| 1 | aaa |
| 2 | bbb |
| 3 | ccc |
| 4 | bbb |
| 5 | ddd |
| 6 | eee |
| 7 | aaa |
| 8 | aaa |
| 9 | eee |

중복 이메일을 삭제하고 최신 이메일을 유지하려면 , 다음 쿼리를 실행할 수 있습니다.

DELETE test
FROM test
INNER JOIN (
  SELECT MAX(id) AS lastId, email
  FROM test
  GROUP BY email
  HAVING COUNT(*) > 1
) duplic ON duplic.email = test.email
WHERE test.id < duplic.lastId;

이 쿼리는 중복 이메일의 최신 ID를 검색하고 이전 ID가 있는 모든 중복 항목을 제거합니다. 쿼리를 실행하면 테스트 테이블이 다음과 같이 나타납니다.

| id | email |
|---|---|
| 3 | ccc |
| 4 | bbb |
| 5 | ddd |
| 8 | aaa |
| 9 | eee |

ID가 가장 높은 최신 중복 항목만 보존되어 테이블에서 가장 최근 이메일 주소를 유지해야 한다는 요구 사항을 충족합니다.

위 내용은 최신을 유지하면서 MySQL에서 중복 레코드를 삭제하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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