>데이터 베이스 >MySQL 튜토리얼 >MySQL 오류 150: 왜 이 외래 키를 생성할 수 없나요?

MySQL 오류 150: 왜 이 외래 키를 생성할 수 없나요?

Barbara Streisand
Barbara Streisand원래의
2024-11-27 05:19:14800검색

MySQL Error 150: Why Can't I Create This Foreign Key?

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

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