> 데이터 베이스 > MySQL 튜토리얼 > MySQL에 외래 키 제약 조건을 추가할 수 없는 이유는 무엇입니까?

MySQL에 외래 키 제약 조건을 추가할 수 없는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-18 20:16:10
원래의
841명이 탐색했습니다.

Why Can't I Add a Foreign Key Constraint in MySQL?

MySQL 외래 키 제약 조건 오류 문제 해결

MySQL의 FK(외래 키) 제약 조건은 테이블을 연결하여 데이터 무결성을 보장합니다. 그러나 FK를 추가하면 오류가 발생할 수 있는 경우가 있습니다. 이 가이드는 일반적인 "외래 키 제약 조건을 추가할 수 없음" 문제를 해결하는 데 도움이 됩니다.

문제:

PatientAppointment 테이블 사이에 FK 제약 조건을 추가할 때 다음 오류가 발생할 수 있습니다.

<code>ERROR 1215 (HY000): Cannot add foreign key constraint</code>
로그인 후 복사

원인 찾기:

문제를 진단하려면 다음 명령을 사용하세요.

<code class="language-sql">SHOW ENGINE INNODB STATUS;</code>
로그인 후 복사

출력의 "LATEST FOREIGN KEY ERROR" 섹션을 주의 깊게 살펴보세요.

해결책:

자주 발생하는 원인은 하위 열과 상위 열 간의 데이터 유형 불일치입니다. 예:

  • Patient.MedicalHistory(어린이)는 SMALLINT일 수 있습니다.
  • medicalhistory.MedicalHistoryID(부모)는 INT일 수 있습니다.

수정은요? 하위 열의 데이터 유형이 상위 열의 데이터 유형과 정확히 일치하는지 확인하세요. 이 시나리오에서는 Patient.MedicalHistoryINT으로 변경합니다.

권장 방법:

FK가 포함된 테이블을 만들기 전에 다음 명령을 실행하세요.

<code class="language-sql">SET FOREIGN_KEY_CHECKS=0;</code>
로그인 후 복사

이렇게 하면 상위 테이블 누락으로 인한 FK 제약 조건 오류 없이 순서에 관계없이 테이블을 생성할 수 있습니다. 나중에 FK 확인을 다시 활성화하는 것을 잊지 마세요:

<code class="language-sql">SET FOREIGN_KEY_CHECKS=1;</code>
로그인 후 복사

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

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