외래 키 제약 조건에 사용된 인덱스를 삭제할 수 없음
새 열을 추가하고 UNIQUE 인덱스를 업데이트하여 데이터베이스를 수정하려고 할 때 이 열을 포함하면 "MySQL은 외래 키 제약 조건에 필요한 인덱스를 삭제할 수 없습니다."라는 오류가 발생할 수 있습니다. 이는 삭제되는 인덱스가 다른 테이블의 외래 키에 의해 참조되는 경우에 발생합니다.
문제 이해
MySQL은 외래 키가 있는 테이블에 인덱스를 자동으로 생성합니다. 이는 참조 무결성과 효율적인 데이터 검색을 보장하기 위해 수행됩니다. 외래 키가 정의되면 MySQL은 참조 테이블의 열에 해당하는 참조 테이블의 열에 인덱스를 생성합니다. 인덱스를 삭제하면 외래 키 관계의 무결성이 침해됩니다.
문제 해결
이 문제를 해결하려면 다음을 참조하는 외래 키 제약 조건을 제거해야 합니다. 색인. 다음 구문을 사용하여 이 작업을 수행할 수 있습니다.
ALTER TABLE [table_name] DROP FOREIGN KEY [foreign_key_name];
외래 키 제약 조건이 삭제되면 오류 없이 인덱스를 제거할 수 있습니다.
예:
다음 예를 고려하세요.
CREATE TABLE mytable ( ID int(11) NOT NULL AUTO_INCREMENT, AID tinyint(5) NOT NULL, BID tinyint(5) NOT NULL, CID tinyint(5) NOT NULL, PRIMARY KEY (ID), UNIQUE INDEX AID (AID, BID, CID), FOREIGN KEY (AID) REFERENCES mytable_a (ID) ON DELETE CASCADE, FOREIGN KEY (BID) REFERENCES mytable_b (ID) ON DELETE CASCADE, FOREIGN KEY (CID) REFERENCES mytable_c (ID) ON DELETE CASCADE );
UNIQUE를 삭제하려면 INDEX AID에서는 먼저 다음 명령문을 사용하여 외래 키 제약 조건 mytable_ibfk_1을 삭제해야 합니다.
ALTER TABLE mytable DROP FOREIGN KEY mytable_ibfk_1;
외래 키 제약 조건을 제거한 후 인덱스를 성공적으로 삭제할 수 있습니다.
위 내용은 외래 키 제약 조건에 사용된 인덱스를 삭제할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!