> 데이터 베이스 > MySQL 튜토리얼 > .sql 파일을 가져올 때 MySQL에서 '테이블을 만들 수 없습니다(errno: 150)' 오류가 발생하는 이유는 무엇입니까?

.sql 파일을 가져올 때 MySQL에서 '테이블을 만들 수 없습니다(errno: 150)' 오류가 발생하는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-20 02:22:09
원래의
439명이 탐색했습니다.

Why Am I Getting a

MySQL 오류: "테이블을 생성할 수 없습니다(errno: 150)" - 문제 해결 가이드

문제:

테이블 생성 중에 테이블 정의가 포함된 SQL 파일 가져오기가 실패하고 "Can't create table './dbname/data.frm'(errno: 150)" 오류가 발생합니다.

근본 원인:

MySQL FOREIGN KEY Constraints 문서에 자세히 설명된 대로 이 오류는 테이블 재생성이 테이블을 참조하는 기존 외래 키 제약 조건과 충돌할 때 발생합니다. 다시 생성된 테이블은 다음 측면에서 원본과 정확히 일치해야 합니다.

  • 열 이름 및 데이터 유형: 정확한 대응이 중요합니다.
  • 참조 키의 인덱스: 외래 키 관계와 관련된 열에 필요한 모든 인덱스가 있어야 합니다.

해상도:

이 문제를 해결하려면 다음 사항을 꼼꼼하게 확인하세요.

  • 열 일관성: SQL 파일의 테이블 정의에 있는 열 이름과 데이터 유형이 외래 키 제약 조건에서 참조하는 테이블의 것과 동일한지 확인하세요. 사소한 불일치(예: 다른 문자 집합)라도 이 오류를 유발할 수 있습니다.
  • 인덱스 무결성: 외래 키 관계와 관련된 열의 인덱스를 다시 만듭니다. 이러한 인덱스가 존재하고 원본 테이블의 인덱스 사양과 일치하는지 확인하세요.

이러한 측면을 확인한 후 SQL 가져오기를 다시 시도하세요. 문제가 지속되면 SQL 파일 내의 CREATE TABLE 문에 불일치가 있는지 주의 깊게 검사하세요.

위 내용은 .sql 파일을 가져올 때 MySQL에서 '테이블을 만들 수 없습니다(errno: 150)' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿