최신 데이터를 보존하면서 MySQL에서 중복 레코드 삭제
데이터베이스에서, 특히 고유 식별자가 있는 테이블에서 중복 레코드를 발견하는 것이 일반적입니다. . MySQL에서는 이메일이 중복되는 상황이 발생할 수 있으며, 가장 최근 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!