MySQL: InnoDB에서 ALTER IGNORE TABLE의 제한 사항 이해
ALTER IGNORE TABLE 명령은 MySQL에서 중복 항목을 제거하는 데 도움을 주기 위한 것입니다. 고유 인덱스를 추가하여 테이블을 만듭니다. 그러나 이 명령을 적용할 때 "무결성 제약 조건 위반" 오류와 같은 예상치 못한 오류가 사용자에게 발생했습니다.
MySQL 문서에 따르면 IGNORE 키워드는 변경 프로세스 중에 중복 키 오류를 무시할 수 있도록 허용해야 합니다. 그러나 특정 릴리스의 InnoDB 버전 MySQL에서 명백한 버그가 확인되었습니다. 이 버그로 인해 IGNORE 키워드가 예상대로 작동하지 않습니다.
해결 방법으로 사용자는 테이블을 MyISAM으로 변환하고 IGNORE로 고유 인덱스를 추가한 다음 다시 InnoDB로 변환하는 것을 고려할 수 있습니다. 이 프로세스는 다음과 같이 설명됩니다.
ALTER TABLE table ENGINE MyISAM; ALTER IGNORE TABLE table ADD UNIQUE INDEX dupidx (field); ALTER TABLE table ENGINE InnoDB;
테이블에 외래 키 제약 조건이 있는 경우 이 솔루션이 실행 가능하지 않을 수 있다는 점에 유의하는 것이 중요합니다. 이러한 제약 조건은 변환 전에 제거한 다음 추가해야 하기 때문입니다. 나중에 다시.
위 내용은 InnoDB에서 ALTER IGNORE TABLE이 실패하는 이유와 해결 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!