>  기사  >  데이터 베이스  >  MySQL 외래 키 오류 1215: \'외래 키 제약 조건을 추가할 수 없습니다\'가 나타나는 이유는 무엇입니까?

MySQL 외래 키 오류 1215: \'외래 키 제약 조건을 추가할 수 없습니다\'가 나타나는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-25 14:08:13825검색

Why Am I Getting MySQL Foreign Key Error 1215:

MySQL 외래 키 오류 문제 해결: 1215

MySQL에서 외래 키 제약 조건을 추가하려고 하면 다음을 나타내는 오류 코드: 1215가 발생할 수 있습니다. "외래 키 제약 조건(외래 키)을 추가할 수 없습니다." 이 오류는 일반적으로 데이터 유형 불일치 또는 구조적 문제로 인해 발생합니다.

데이터 유형 불일치

한 가지 가능한 원인은 외래 키를 참조하는 열 간의 데이터 유형 불일치입니다. 그리고 참조된 열입니다. 예를 들어, 클래스 테이블의 classLeader 열에 데이터 유형이 VARCHAR(255)이고 학생 테이블에서 참조된 StudentID 열이 INT인 경우 외래 키 제약 조건이 실패합니다. 두 열의 데이터 유형은 동일해야 합니다.

구조적 문제

데이터 유형이 일치하는 경우 테이블 간의 구조적 불일치로 인해 문제가 발생할 수 있습니다. 특히:

  • 참조된 테이블(이 경우 학생)이 존재해야 합니다.
  • 참조된 열(studentID)이 참조된 테이블 내에 존재해야 합니다.
  • 참조된 테이블 열(studentID)은 참조된 테이블의 기본 키 또는 고유 키여야 합니다(MySQL에서는 인덱스가 충분).

-- Create student table
CREATE TABLE student (
  studentID int NOT NULL AUTO_INCREMENT,
  lastName varchar(255),
  firstName varchar(255),
  PRIMARY KEY (studentID)
);

-- Create class table
CREATE TABLE class (
  classID int NOT NULL AUTO_INCREMENT,
  nameClass varchar(255),
  classLeader int,  -- Change to INT to match studentID type
  FOREIGN KEY (classLeader) REFERENCES student(studentID),
  PRIMARY KEY (classID)
);

외래 키와 키

외래 키는 고려되지 않습니다. 테이블 내의 행을 고유하게 식별하는 기존 키(예: 기본 키 또는 고유 키)입니다. 대신, 주요 목적은 참조 무결성을 보장하고 테이블 간의 관계를 유지하는 것입니다. 외래 키를 적용하면 불일치 및 고아 데이터를 방지할 수 있습니다.

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

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