집 >데이터 베이스 >MySQL 튜토리얼 >MySQL 오류 150: 왜 이 외래 키를 생성할 수 없나요?
MySql에서 오류 150 발생: 외래 키 해독 문제
다른 테이블을 참조하는 외래 키를 사용하여 테이블을 생성하려고 할 때 개발자는 다음과 같은 문제가 발생할 수 있습니다. 오류 150, 비밀스러운 메시지로 그들을 당황하게 합니다. 이 문서에서는 이 오류의 근본 원인을 자세히 알아보고 해결 방법을 제공합니다.
MySQL 문서에 자세히 설명된 대로 이전에 삭제된 테이블을 다시 생성할 때 이를 참조하는 외래 키 제약 조건을 준수하지 않으면 오류 150이 발생합니다. 특히 테이블은 참조 키에 대해 원래 생성되었을 때와 동일한 열 이름, 유형 및 인덱스를 유지해야 합니다.
이 문제를 해결하려면 테이블에 외래 키가 포함되어 있는지 확인하세요(이 경우 "foo")도 InnoDB 테이블로 생성됩니다. MySQL 문서에 따르면 외래 키 관계에 관련된 두 테이블은 모두 임시 테이블이 아닌 InnoDB 테이블이어야 합니다.
따라서 오류를 수정하려면 다음을 사용하여 "foo" 테이블을 InnoDB 테이블로 다시 생성해 보세요. 쿼리:
CREATE TABLE foo ( id INT PRIMARY KEY ) ENGINE = InnoDB;
"foo" 테이블이 InnoDB 테이블로 생성되면 외래 키를 사용하여 "bar" 테이블을 성공적으로 생성할 수 있습니다. 오류 150이 발생하지 않고 참조됩니다.
위 내용은 MySQL 오류 150: 왜 이 외래 키를 생성할 수 없나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!