>  기사  >  데이터 베이스  >  ALTER IGNORE TABLE이 MySQL에서 여전히 "중복 항목" 오류를 발생시키는 이유는 무엇입니까?

ALTER IGNORE TABLE이 MySQL에서 여전히 "중복 항목" 오류를 발생시키는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-08 02:29:02328검색

Why Does ALTER IGNORE TABLE Still Throw a

MySQL: ALTER IGNORE TABLE은 문서에도 불구하고 "무결성 제약 조건 위반"을 발생시킵니다.

MySQL 문서에는 결합 시 ALTER IGNORE TABLE을 사용한다고 명확하게 명시되어 있습니다. UNIQUE KEY를 사용하면 중복 키 오류를 무시하여 중복 제거를 허용해야 합니다. 그러나 실제로 사용자는 "#1062 - 'dupidx' 키에 대한 'blabla' 항목이 중복되었습니다."라는 오류 메시지가 계속 표시되었습니다.

이 동작은 MySQL InnoDB 버전의 버그로 인해 발생한 것으로 보입니다. 특정 버전. 특히 IGNORE 키워드 확장은 InnoDB 컨텍스트에서 예상대로 작동하지 않습니다.

해결책:

이 문제를 피하려면 사용자는 다음 해결 방법을 사용할 수 있습니다.

  1. ALTER TABLE table ENGINE을 사용하여 테이블을 MyISAM으로 변환합니다. MyISAM;
  2. UNIQUE INDEX를 사용하여 ALTER IGNORE TABLE 명령 적용: ALTER IGNORE TABLE table ADD UNIQUE INDEX dupidx(필드);
  3. 다음을 사용하여 테이블을 다시 InnoDB로 변환: ALTER TABLE table ENGINE InnoDB;

참고: 테이블에 외래 키 제약 조건이 포함된 경우 데이터 무결성을 보장하기 위해 이를 제거하고 다시 추가해야 합니다.

위 내용은 ALTER IGNORE TABLE이 MySQL에서 여전히 "중복 항목" 오류를 발생시키는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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