>데이터 베이스 >MySQL 튜토리얼 >'Sprache'를 참조하는 'katalog' 테이블에 외래 키를 추가할 수 없는 이유는 무엇입니까?

'Sprache'를 참조하는 'katalog' 테이블에 외래 키를 추가할 수 없는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-29 17:19:09839검색

Why Can't I Add a Foreign Key to My

기존 테이블에 외래 키 추가

기존 테이블에 외래 키를 추가하는 것은 간단한 작업일 수 있지만 때로는 오류가 발생할 수 있습니다. 부적절한 구문이나 테이블 구성 문제로 인해 발생합니다.

이 특정 시나리오에서 사용자는 "Sprache" 테이블을 참조하여 "katalog" 테이블에 외래 키 제약 조건을 추가하려고 할 때 오류가 발생합니다. 오류 메시지는 외래 키 정의에서 "Sprache" 테이블을 확인할 수 없음을 나타냅니다.

이 문제를 해결하려면 "katalog" 및 "Sprache" 테이블이 모두 데이터베이스에 있고 올바르게 정의되었는지 확인하세요. . 외래 키 제약 조건에서 참조되는 열 이름이 두 테이블 모두에 존재하고, 데이터 형식이 일치하며, NULL이 아닌지 확인하세요. 또한 테이블 엔진을 확인하십시오. 외래 키 제약 조건이 올바르게 작동하려면 두 테이블 모두 InnoDB 스토리지 엔진을 사용해야 합니다.

테이블 구성이 올바른 경우 ALTER TABLE 문의 구문에 문제가 있을 수 있습니다. MySQL 5.1.61에서 외래 키를 추가하는 올바른 구문은 다음과 같습니다.

ALTER TABLE katalog ADD FOREIGN KEY (Sprache) REFERENCES Sprache (ID) ON DELETE SET NULL ON UPDATE SET NULL;

열 이름, 테이블 이름 및 작업 절의 철자가 모두 올바른지 확인하세요. 또한 FOREIGN KEY 절에서 참조하는 테이블이 데이터베이스에 존재하고 기본 키가 정의되어 있는지 확인하세요.

테이블 구성을 확인하고 올바른 구문을 확인하면 외래 키를 성공적으로 추가할 수 있어야 합니다. "katalog" 테이블에 대한 키 제약 조건

위 내용은 'Sprache'를 참조하는 'katalog' 테이블에 외래 키를 추가할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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