>  기사  >  데이터 베이스  >  외래 키 제약 조건에 사용된 인덱스를 삭제할 수 없는 이유는 무엇입니까?

외래 키 제약 조건에 사용된 인덱스를 삭제할 수 없는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-01 06:51:30200검색

Why Can't I Drop an Index Used in a Foreign Key Constraint?

외래 키 제약 조건에 사용된 인덱스를 삭제할 수 없음

새 열을 추가하고 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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